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产品

相关推荐
考虑考虑3 小时前
JDK25中的StructuredTaskScope
java·后端·java ee
yumgpkpm3 小时前
CMP (类Cloudera) CDP7.3(400次编译)在华为鲲鹏Aarch64(ARM)信创环境中的性能测试过程及命令
大数据·hive·hadoop·python·elasticsearch·spark·cloudera
workpieces3 小时前
Claude Code 插件系统发布:AI 编程助手进入「可定制化」时代
后端
用户5965906181343 小时前
appsettings.json 在 ASP.NET Core 中默认加载时,reloadOnChange 参数为 true,即支持配置文件变更自动重新加载。
后端
SimonKing3 小时前
「String到Date转换失败」:深挖@RequestBody的日期坑
java·后端·程序员
CryptoRzz3 小时前
python对接印度尼西亚股票数据接口文档
后端
渣哥4 小时前
Lazy能否有效解决循环依赖?答案比你想的复杂
javascript·后端·面试
qq_12498707534 小时前
基于Spring Boot的网上招聘服务系统(源码+论文+部署+安装)
java·spring boot·后端·spring·计算机外设
代码小菜鸡6664 小时前
java 常用的一些数据结构
java·数据结构·python