微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Google使用VBA转换单元格值

如何解决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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?