更新时间:2024-10-10 GMT+08:00

文本内容审核(v2)

  1. 本章节对文本内容审核AK/SK方式使用SDK进行示例说明。

    示例代码中修改TextDetectionItemsReq的text值配置待检测的文本信息,配置完成后运行即可。

     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
    # coding: utf-8
    
    from huaweicloudsdkcore.auth.credentials import BasicCredentials
    from huaweicloudsdkcore.exceptions import exceptions
    from huaweicloudsdkmoderation.v2.region.moderation_region import ModerationRegion
    from huaweicloudsdkmoderation.v2 import ModerationClient,RunTextModerationRequest,TextDetectionItemsReq,TextDetectionReq
    import os
    
    
    if __name__ == "__main__":
        # 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险建议在配置文件或者环境变量中密文存放使用时解密确保安全
        # 本示例以ak和sk保存在环境变量中来实现身份验证为例运行本示例前请先在本地环境中设置环境变量HUAWEICLOUD_SDK_AK和HUAWEICLOUD_SDK_SK
        ak = os.getenv("HUAWEICLOUD_SDK_AK")
        sk = os.getenv("HUAWEICLOUD_SDK_SK")
    
        credentials = BasicCredentials(ak, sk)
    
        client = ModerationClient.new_builder() \
            .with_credentials(credentials) \
            .with_region(ModerationRegion.value_of("xxx")) \   //把xxx替换成服务所在的区域,例如新加坡:ap-southeast-3。
            .build()
    
        try:
            request = RunTextModerationRequest()
            listTextDetectionItemsReqItemsbody = [
                TextDetectionItemsReq(
                    text="text",  //此处输入待检测文本
                    type="content"
                )
            ]
            listTextDetectionReqCategoriesbody = [
                "porn",
                "abuse",
                "contraband",
                "flood"
            ]
            request.body = TextDetectionReq(
                items=listTextDetectionItemsReqItemsbody,
                categories=listTextDetectionReqCategoriesbody
            )
            response = client.run_text_moderation(request)
            print(response.status_code)
            print(response)
        except exceptions.ClientRequestException as e:
            print(e.status_code)
            print(e.request_id)
            print(e.error_code)
            print(e.error_msg)
    
  2. 控制台输出200即表示程序执行成功,文本内容审核结果输出到控制台。
    200
    {"result": {"suggestion": "block", "detail": {"contraband": ["亚砷酸钾"], "porn": ["luo聊"]}}}}