VBScript
VBScript
Find a Label ID by Name
See more GMail REST API Examples
Lookup the ID of a GMail label by the label name.Chilkat VBScript Downloads
Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)
success = 0
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
set http = CreateObject("Chilkat.Http")
http.AuthToken = "GMAIL-ACCESS-TOKEN"
userId = "me"
success = http.SetUrlVar("userId",userId)
url = "https://www.googleapis.com/gmail/v1/users/{$userId}/labels"
' Get the list of GMail labels as JSON.
set sb = CreateObject("Chilkat.StringBuilder")
success = http.QuickGetSb(url,sb)
If (success <> 1) Then
outFile.WriteLine(http.LastErrorText)
WScript.Quit
End If
set json = CreateObject("Chilkat.JsonObject")
success = json.LoadSb(sb)
json.EmitCompact = 0
outFile.WriteLine(json.Emit())
If (http.LastStatus <> 200) Then
outFile.WriteLine("Failed.")
WScript.Quit
End If
' The JSON returned looks like this:
' {
' "labels": [
' {
' "id": "Label_5",
' "name": "QA",
' "messageListVisibility": "show",
' "labelListVisibility": "labelShow",
' "type": "user"
' },
' {
' "id": "Label_21",
' "name": "[Gmail]/testFolder",
' "type": "user"
' },
' {
' "id": "CATEGORY_PERSONAL",
' "name": "CATEGORY_PERSONAL",
' "type": "system"
' },
' ...
' The name of the label is generally known because it's what we visually see.
' The id is what we need to get. Assuming the name is unique,
' find the JSON record having name=<desired name>
' For example...
' jRecord is a Chilkat.JsonObject
Set jRecord = json.FindRecord("labels","name","QA",0)
If (json.LastMethodSuccess = 1) Then
outFile.WriteLine("The id of QA is: " & jRecord.StringOf("id"))
End If
' jRecord is a Chilkat.JsonObject
Set jRecord = json.FindRecord("labels","name","[Gmail]/testFolder",0)
If (json.LastMethodSuccess = 1) Then
outFile.WriteLine("The id of [Gmail]/testFolder is: " & jRecord.StringOf("id"))
End If
' jRecord is a Chilkat.JsonObject
Set jRecord = json.FindRecord("labels","name","questions",0)
If (json.LastMethodSuccess = 1) Then
outFile.WriteLine("The id of questions is: " & jRecord.StringOf("id"))
End If
' Output:
' The id of QA is: Label_5
' The id of [Gmail]/testFolder is: Label_21
' The id of questions is: Label_43
outFile.Close