How to call the Text Analytics REST API
Calls to the Text Analytics API are HTTP POST/GET calls, which you can formulate in any language. In this article, we use REST and Postman to demonstrate key concepts.
Each request must include your access key and an HTTP endpoint. The endpoint specifies the region you chose during sign up, the service URL, and a resource used on the request:
Recall that Text Analytics is stateless so there are no data assets to manage. Your text is uploaded, analyzed upon receipt, and results are returned immediately to the calling application.
For one-off calls to see how the API works, you can send POST requests from the built-in API testing console, available on any API doc page. There is no setup, and the only requirements are to paste an access key and the JSON documents into the request.
JSON schema definition
Input must be JSON in raw unstructured text. XML is not supported. The schema is simple, consisting of the elements described in the following list.
You can currently submit the same documents for all Text Analytics operations: sentiment, key phrase, language detection, and entity identification. (The schema is likely to vary for each analysis in the future.)
||The data type is string, but in practice document IDs tend to be integers.||Required||The system uses the IDs you provide to structure the output. Language codes, key phrases, and sentiment scores are generated for each ID in the request.|
||Unstructured raw text, up to 5,000 characters.||Required||For language detection, text can be expressed in any language. For sentiment analysis, key phrase extraction and entity identification, the text must be in a supported language.|
||2-character ISO 639-1 code for a supported language||Varies||Required for sentiment analysis, key phrase extraction, and entity linking; optional for language detection. There is no error if you exclude it, but the analysis is weakened without it. The language code should correspond to the
For more information about limits, see Text Analytics Overview > Data limits.
Set up a request in Postman
The service accepts request up to 1 MB in size. If you are using Postman (or another Web API test tool), set up the endpoint to include the resource you want to use, and provide the access key in a request header. Each operation requires that you append the appropriate resource to the endpoint.
- Choose Post as the request type.
- Paste in the endpoint you copied from the portal page.
- Append a resource.
Resource endpoints are as follows (your region may vary):
Set the three request headers:
Ocp-Apim-Subscription-Key: your access key, obtained from Azure portal.
Your request should look similar to the following screenshot, assuming a /keyPhrases resource.
Click Body and choose raw for the format.
Paste in some JSON documents in a format that is valid for the intended analysis. For more information about a particular analysis, see the topics below:
Click Send to submit the request. You can submit up to 100 requests per minute.
In Postman, the response is displayed in the next window down, as a single JSON document, with an item for each document ID provided in the request.
We'd love to hear your thoughts. Choose the type you'd like to provide:
Our feedback system is built on GitHub Issues. Read more on our blog.