File: sample_get_detailed_diagnostics_information.py

package info (click to toggle)
python-azure 20250603%2Bgit-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 851,724 kB
  • sloc: python: 7,362,925; ansic: 804; javascript: 287; makefile: 195; sh: 145; xml: 109
file content (70 lines) | stat: -rw-r--r-- 2,837 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# -------------------------------------------------------------------------
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License. See License.txt in the project root for
# license information.
# --------------------------------------------------------------------------

"""
FILE: sample_get_detailed_diagnostics_information.py

DESCRIPTION:
    This sample demonstrates how to retrieve batch statistics, the
    model version used, and the raw response in JSON format returned from the service.

USAGE:
    python sample_get_detailed_diagnostics_information.py

    Set the environment variables with your own values before running the sample:
    1) AZURE_LANGUAGE_ENDPOINT - the endpoint to your Language resource.
    2) AZURE_LANGUAGE_KEY - your Language subscription key
"""


def sample_get_detailed_diagnostics_information() -> None:
    import os
    import logging
    import json
    from azure.core.credentials import AzureKeyCredential
    from azure.ai.textanalytics import TextAnalyticsClient
    _LOGGER = logging.getLogger(__name__)

    endpoint = os.environ["AZURE_LANGUAGE_ENDPOINT"]
    key = os.environ["AZURE_LANGUAGE_KEY"]

    # This client will log detailed information about its HTTP sessions, at DEBUG level
    text_analytics_client = TextAnalyticsClient(endpoint=endpoint, credential=AzureKeyCredential(key), logging_enable=True)

    documents = [
        """I had the best day of my life. I decided to go sky-diving and it made me appreciate my whole life so much more.
        I developed a deep-connection with my instructor as well.
        """,
        "This was a waste of my time. The speaker put me to sleep.",
        "No tengo dinero ni nada que dar...",
        "L'hôtel n'était pas très confortable. L'éclairage était trop sombre."
    ]

    json_responses = []

    def callback(resp):
        _LOGGER.debug("document_count: {}".format(resp.statistics["document_count"]))
        _LOGGER.debug("valid_document_count: {}".format(resp.statistics["valid_document_count"]))
        _LOGGER.debug("erroneous_document_count: {}".format(resp.statistics["erroneous_document_count"]))
        _LOGGER.debug("transaction_count: {}".format(resp.statistics["transaction_count"]))
        _LOGGER.debug(f"model_version: {resp.model_version}")
        json_response = json.dumps(resp.raw_response)
        json_responses.append(json_response)

    result = text_analytics_client.extract_key_phrases(
        documents,
        show_stats=True,
        model_version="latest",
        raw_response_hook=callback
    )
    for doc in result:
        _LOGGER.warning(f"Doc with id {doc.id} has these warnings: {doc.warnings}")

    _LOGGER.debug(f"json response: {json_responses[0]}")


if __name__ == '__main__':
    sample_get_detailed_diagnostics_information()