Access调用Azure翻译:轻松实现系统多语言切换

hi,大家好!

上一篇文章,我们讲了一个中英文切换的功能,翻译的内容我们都是保存在表中了,那如果遇到多语言的切换该怎么办呢?显然,还是用原来的方法感觉又有点帮不上忙了,所以是不是可以考虑一下,调用API的方式来实现?

今天就和大家聊聊如何调用Azure翻译API,实现Access系统的智能多语言切换。

当然如果要用Azure翻译的话,你先要申请Azure翻译服务,这里我们就不具体的讲了,怎么来注册申请账号之类的,你可以自己先研究一下,后期有时间,我可以单独来讲一下。

创建完成后,进入资源页面,记录:

密钥(Key):a1b2c3d4e5f6...(像密码一样保密)

区域(Region):你申请的区域

终结点:你的终结点地址

申请的时候,你也可以申请F0免费,每月翻译大概有200W个字符

我们按往常那样开发的话,首先我们是需要先做一个窗体,一个表,之类的,因为上一篇文章我们已经讲过类似的功能了,所以这里我们直接把一个函数给到大家,教大家用一下,其他的由大家自己来调整。

具体的代码如下:

翻译代码模块

vbnet 复制代码
'=============================================
' 模块:modAzureTranslator
' 功能:Azure翻译API调用
' 作者:Access开发
'=============================================
Option Compare Database
Option Explicit
'Azure配置(替换为你的密钥)
Private Const AZURE_KEY As String = "123456" '你的Azure翻译密钥
Private Const AZURE_REGION As String = "eastus"  '你的区域
Private Const AZURE_ENDPOINT As String = "https://你的终结点.com/"
'翻译单条文本
Public Function TranslateText(sourceText As String, _
                              fromLang As String, _
                              toLang As String) As String
    On Error GoTo Err_Handler
    
    If Len(Trim(sourceText)) = 0 Then Exit Function
    
    Dim http As Object
    Dim url As String
    Dim requestBody As String
    Dim response As String
    
    '构建API URL
    url = AZURE_ENDPOINT & "translate?api-version=3.0" & _
          "&from=" & fromLang & "&to=" & toLang
    
    '构建JSON请求体
    requestBody = "[{""Text"":""" & EscapeJson(sourceText) & """}]"
    
    '创建HTTP请求
    Set http = CreateObject("MSXML2.XMLHTTP")
    http.Open "POST", url, False
    http.setRequestHeader "Ocp-Apim-Subscription-Key", AZURE_KEY
    http.setRequestHeader "Ocp-Apim-Subscription-Region", AZURE_REGION
    http.setRequestHeader "Content-Type", "application/json; charset=UTF-8"
    http.send requestBody
    
    '解析响应
    If http.status = 200 Then
        response = http.responseText
        TranslateText = ParseTranslation(response)
    Else
        MsgBox "翻译失败: " & http.status & vbCrLf & http.responseText, vbCritical
        TranslateText = ""
    End If
    
    Set http = Nothing
    Exit Function
    
Err_Handler:
    MsgBox "翻译出错: " & Err.Description, vbCritical
    TranslateText = ""
End Function
'批量翻译资源表
Public Sub TranslateAllResources(toLang As String)
    Dim rs As DAO.Recordset
    Dim translated As String
    Dim count As Long
    Dim total As Long
    Dim strSQL As String
    Dim langField As String
    
    '确定目标语言字段
    Select Case toLang
        Case "en": langField = "EN"
        Case "ja": langField = "JA"
        Case "ko": langField = "KO"
        Case Else
            MsgBox "不支持的语言: " & toLang, vbExclamation
            Exit Sub
    End Select
    
    '查询未翻译的记录
    strSQL = "SELECT * FROM tblLanguage WHERE IsTranslated = False OR " & langField & " Is Null"
    Set rs = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
    
    If rs.EOF Then
        MsgBox "没有需要翻译的内容", vbInformation
        rs.Close
        Exit Sub
    End If
    
    rs.MoveLast
    total = rs.RecordCount
    rs.MoveFirst
    
    '显示进度
    SysCmd acSysCmdInitMeter, "正在翻译...", total
    
    Do While Not rs.EOF
        count = count + 1
        SysCmd acSysCmdUpdateMeter, count
        
        '调用翻译
        translated = TranslateText(Nz(rs!cn, ""), "zh-Hans", toLang)
        
        If Len(translated) > 0 Then
            rs.Edit
            rs.fields(langField).value = translated
            rs!IsTranslated = True
            rs!LastUpdate = Now()
            rs.Update
            
            Debug.Print count & "/" & total & ": " & rs!cn & " -> " & translated
        End If
        
        '避免频繁调用触发限流(每秒最多3次)
        If count Mod 3 = 0 Then
            Application.Wait (Now + TimeValue("0:00:01"))
        End If
        
        rs.MoveNext
        DoEvents
    Loop
    
    SysCmd acSysCmdRemoveMeter
    rs.Close
    
    MsgBox "翻译完成!共处理 " & count & " 条记录", vbInformation
End Sub
'批量翻译(带进度窗体版本)
Public Sub TranslateWithProgress(toLang As String)
    Dim rs As DAO.Recordset
    Dim translated As String
    Dim count As Long
    Dim total As Long
    Dim strSQL As String
    Dim langField As String
    
    '打开进度窗体(假设你已创建)
    DoCmd.OpenForm "frmProgress"
    
    Select Case toLang
        Case "en": langField = "EN"
        Case "ja": langField = "JA"
        Case "ko": langField = "KO"
        Case Else: Exit Sub
    End Select
    
    strSQL = "SELECT * FROM tblLanguage WHERE " & langField & " Is Null"
    Set rs = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)
    
    If Not rs.EOF Then
        rs.MoveLast: total = rs.RecordCount: rs.MoveFirst
        
        Do While Not rs.EOF
            count = count + 1
            
            '更新进度条(假设你有ProgressUpdate函数)
            ProgressUpdate Forms!frmProgress, count, total, _
                "翻译中: " & rs!TextKey
            
            translated = TranslateText(rs!cn, "zh-Hans", toLang)
            
            If Len(translated) > 0 Then
                rs.Edit
                rs.fields(langField).value = translated
                rs!IsTranslated = True
                rs!LastUpdate = Now()
                rs.Update
            End If
            
            If count Mod 3 = 0 Then
                Application.Wait (Now + TimeValue("0:00:01"))
            End If
            
            rs.MoveNext
        Loop
    End If
    
    rs.Close
    DoCmd.Close acForm, "frmProgress"
    MsgBox "翻译完成!", vbInformation
End Sub
'转义JSON特殊字符
Private Function EscapeJson(text As String) As String
    text = Replace(text, "\", "\\")
    text = Replace(text, """", "\""")
    text = Replace(text, vbCrLf, "\n")
    text = Replace(text, vbCr, "\n")
    text = Replace(text, vbLf, "\n")
    text = Replace(text, vbTab, "\t")
    EscapeJson = text
End Function
'解析翻译结果JSON
Private Function ParseTranslation(json As String) As String
    Dim pos1 As Long, pos2 As Long
    
    '简单解析:查找 "text":"翻译结果"
    pos1 = InStr(1, json, """text"":""", vbTextCompare)
    If pos1 > 0 Then
        pos1 = pos1 + 8
        pos2 = InStr(pos1, json, """")
        If pos2 > pos1 Then
            ParseTranslation = Mid(json, pos1, pos2 - pos1)
            '还原转义字符
            ParseTranslation = Replace(ParseTranslation, "\n", vbCrLf)
            ParseTranslation = Replace(ParseTranslation, "\\", "\")
            ParseTranslation = Replace(ParseTranslation, "\""", """")
        End If
    End If
End Function

调用测试:

vbscript 复制代码
'测试翻译
Public Sub TestTranslate()
    Dim result As String
    result = TranslateText("客户管理系统", "zh-Hans", "en")
    MsgBox "翻译结果: " & result
End Sub

运行测试效果

翻译成英文

翻译成日文

翻译成法语

OK,那剩下的就由你们自己去扩展啦!

📌 常见问题FAQ

Q1:Azure翻译准确吗?

A:整体很准确(90%+),但要注意:

✅ 通用文本:非常准确

✅ 商务用语:质量高

⚠️ 专业术语:可能需要校对

⚠️ 地方俚语:不太支持

建议:AI翻译 + 人工校对 = 完美组合

适用场景

这套方案特别适合:

  • 外企/合资企业的内部系统

  • 跨境电商后台管理

  • 制造业MES/ERP系统

  • 多语言移动应用后台

  • 国际化SaaS产品

相关推荐
星川皆无恙24 分钟前
基于知识图谱+深度学习的大数据NLP医疗知识问答可视化系统(全网最详细讲解及源码/建议收藏)
大数据·人工智能·python·深度学习·自然语言处理·知识图谱
Tipriest_30 分钟前
旋转矩阵,齐次变换矩阵,欧拉角,四元数等相互转换的常用代码C++ Python
c++·python·矩阵
周杰伦_Jay32 分钟前
【Go/Python/Java】基础语法+核心特性对比
java·python·golang
小鹿学程序37 分钟前
jdk配置完之后java -version还是默认的jdk版本如何更改
java·开发语言·python
用户990450177800942 分钟前
ruoyi-vue2集成DMN规则引擎实现Dish出餐决策
后端
Pyeako42 分钟前
Python数据可视化--matplotlib库
python·matplotlib·数据可视化·画图·pylab
m0_704887891 小时前
Day 35
python·深度学习·机器学习
华研前沿标杆游学1 小时前
参观深圳比亚迪总部,探索科技,感受中国“智”造魅力
python
爱打代码的小林1 小时前
python基础(逻辑回归例题)
开发语言·python·逻辑回归
qq_214782611 小时前
pandas“将”迎来v3.0.0大版本更新!
python·pandas