这是我的代码:
$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..
我认为这是一个哈希表,但我并不肯定。我正在拼命寻求帮助来解析用户名和电子邮件值......
代码没有显示您捕获
$results
中的输出,但您可以简单地输出
$data.result | Select-Object username, email
位于开关中
break
的正上方。
接下来,删除
$data | convertto-json