如何解决Google使用VBA转换单元格值
我正在尝试通过触发以下代码,使用自动检测功能将其他语言转换为英语。
Sub transalte_using_vba()
Dim ie As Object,i As Long
Dim inputstring As String,outputstring As String,text_to_convert As String,result_data As String,CLEAN_DATA
Set ie = CreateObject("InternetExplorer.application")
inputstring = "auto"
outputstring = "en"
text_to_convert = Sheet3.Range("A2")
'open website
ie.Visible = False
ie.navigate "http://translate.google.com/#" & inputstring & "/" & outputstring & "/" & text_to_convert
Do Until ie.ReadyState = 4
DoEvents
Loop
Application.Wait (Now + TimeValue("0:00:5"))
Do Until ie.ReadyState = 4
DoEvents
Loop
CLEAN_DATA = Split(Application.WorksheetFunction.Substitute(ie.Document.getElementById("result_Box").innerHTML,"</SPAN>",""),"<")
For i = LBound(CLEAN_DATA) To UBound(CLEAN_DATA)
result_data = result_data & Right(CLEAN_DATA(i),Len(CLEAN_DATA(i)) - InStr(CLEAN_DATA(i),">"))
Next
Sheet3.Range("B2") = result_data
ie.Quit
MsgBox "Done",vbOKOnly
End Sub
但是我在第CLEAN_DATA = Split(Application.WorksheetFunction.Substitute(ie.Document.getElementById("result_Box").innerHTML,"<")
行中遇到了需要运行时错误424对象
代码有什么问题?
这段代码的工作速度有点慢。因为我需要处理超过70K的批量数据,有什么快速的方法吗?
在我的系统中,我将google chrome作为默认浏览器,我们可以将其用于翻译,这可能有助于更快地运行脚本吗?
解决方法
基于Internet Explorer的解决方案从定义上讲非常慢。请尝试下一个功能:
Private Function GTranslate(strInput As String,strFromLang As String,strToLang As String) As String
Dim strURL As String,objHTTP As Object,objHTML As Object,objDivs As Object,objDiv As Variant
strInput = WorksheetFunction.EncodeURL(strInput)
strURL = "https://translate.google.com/m?hl=" & strFromLang & _
"&sl=" & strFromLang & _
"&tl=" & strToLang & _
"&ie=UTF-8&prev=_m&q=" & strInput
Set objHTTP = CreateObject("MSXML2.ServerXMLHTTP")
objHTTP.Open "GET",strURL,False
objHTTP.setRequestHeader "User-Agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)"
objHTTP.Send ""
Set objHTML = CreateObject("htmlfile")
With objHTML
.Open
.Write objHTTP.responseText
.Close
End With
Set objDivs = objHTML.getElementsByTagName("div")
For Each objDiv In objDivs
If objDiv.className = "t0" Then
GTranslate = objDiv.innerText: Exit For
End If
Next objDiv
Set objHTML = Nothing: Set objHTTP = Nothing
End Function
可以通过以下简单方式对其进行测试:
Sub testTranslateG()
Debug.Print GTranslate("Libro muy grande","auto","en")
End Sub
或转换范围内的单元格值:
Private Sub Google_translate()
Dim thisWbs As Worksheet
Dim i As Long,lastRow As Long
Set thisWbs = ActiveSheet
lastRow = thisWbs.Range("B" & rows.count).End(xlUp).row
thisWbs.Range("C2:C" & lastRow).Clear
For i = 2 To lastRow
thisWbs.Range("C" & i).Value = GTranslate(thisWbs.Range("B" & i).Value,"en")
Next i
MsgBox "Ready..."
End Sub
为了获得更准确的翻译,您可以使用(而不是“ auto”):“ es”代表西班牙语,“ ru”代表俄语,“ ro”代表罗马尼亚语,“ nl”代表“ Duch”等。您可以通过查看Google翻译源并搜索“英语”来找到语言的缩写。您会发现一个区域,其中所有可能出现的语言及其缩写都将被使用...
,@FaneDuru 解决方案适用于这些修复:
与Youtube Automate Language Translations Using Excel VBA by Dinesh Kumar Takyar类似
"t0"
已更改。
用
替换If objDiv.className = "t0" Then
If objDiv.className = "result-container" Then
注意:不要看谷歌翻译常规网页HTML,“/m?”代表“移动”,使用 Google 翻译移动页面,该页面具有不同且更简单的 HTML 代码。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。