正确格式化 Invoke-RestMethod 结果?

问题描述 投票:0回答:1

这是我的代码:

$token = 'xxxxxxxxxxxxx'
$uri = "https://api.sendgrid.com/v3/teammates?limit=500&offset=0"
$subuser = Read-Host "Enter the Subuser value"
$headers1 = @{"Authorization" = "Bearer $token" 
    "on-behalf-of" = "$subuser"
}

Do {
    Write-Host "Do you know the teammates username? Y/N" -ForegroundColor Yellow
    $response = Read-Host
}
While ($response.ToLower() -notin "y", "n")

Switch ($response.ToLower())
{
    "y" {
        $username = Read-host "Enter Username"
        $apiurl = $uri + $username
        $data = Invoke-RestMethod -Method Get -Uri $apiurl -headers $headers1
        break
    }
    "n" {
        $uri = $uri 
        $data = Invoke-RestMethod -method GET -uri $uri -headers $headers1 
        
        break
    }
}
$data | convertto-json

所以

$results
的值为:

{
    "result":  [
                   {
                       "username":  "ben.michael",
                       "email":  "[email protected]",
                       "first_name":  "Ben",
                       "last_name":  "Michael",
                       "address":  "",
                       "address2":  "",
                       "city":  "",
                       "state":  "",
                       "zip":  "",
                       "country":  "",
                       "company":  "",
                       "website":  "",
                       "phone":  "",
                       "is_admin":  false,
                       "is_sso":  false,
                       "user_type":  "teammate"
                   },
                   {
                       "username":  "brandon.nosk",
                       "email":  "[email protected]",
                       "first_name":  "Brandon",
                       "last_name":  "Nosk",
                       "address":  "",
                       "address2":  "",
                       "city":  "",
                       "state":  "",
                       "zip":  "",
                       "country":  "",
                       "company":  "",
                       "website":  "",
                       "phone":  "",
                       "is_admin":  false,
                       "is_sso":  false,
                       "user_type":  "teammate"
                   },

我需要做的是能够

Format-Table username, email
但是由于这是一个
PSCustomObject
我无法找出正确的方法。如果我删除
ConvertTo-JSON
那么
$results
的值为:

result                                                                                                                      
------                                                                                                                      
{@{username=ben.michael; [email protected]; first_name=Ben; last_name=Michael; address=; address2=; ci..

我认为这是一个哈希表,但我并不肯定。我正在拼命寻求帮助来解析用户名和电子邮件值......

powershell scripting sendgrid
1个回答
2
投票

代码没有显示您捕获

$results
中的输出,但您可以简单地输出

$data.result | Select-Object username, email

位于开关中

break
的正上方。

接下来,删除

$data | convertto-json

© www.soinside.com 2019 - 2024. All rights reserved.