excel - 在 VBA 中查找单词的英文定义

标签 excel vba

在 Excel 中,如果我在单元格中输入单词“PIZZA”,选择它,然后按 SHIFT+F7,我可以获得我最喜欢的食物的漂亮英语词典定义。很酷。 但我想要一个能做到这一点的函数。类似于 '=DEFINE("PIZZA")'。

有没有办法通过VBA脚本访问微软的研究数据?我正在考虑使用 JSON 解析器和免费的在线词典,但 Excel 似乎内置了一个不错的词典。关于如何访问它有什么想法吗?

最佳答案

如果 VBA 的 Research 对象不起作用,您可以尝试 Google Dictionary JSON 方法,如下所示:

首先,添加对“Microsoft WinHTTP Services”的引用。

在您看到我疯狂的 JSON 解析技巧后,您可能还想添加您最喜欢的 VB JSON 解析器,like this one .

然后创建以下公共(public)函数:

Function DefineWord(wordToDefine As String) As String

  ' Array to hold the response data.
    Dim d() As Byte
    Dim r As Research


    Dim myDefinition As String
    Dim PARSE_PASS_1 As String
    Dim PARSE_PASS_2 As String
    Dim PARSE_PASS_3 As String
    Dim END_OF_DEFINITION As String

    'These "constants" are for stripping out just the definitions from the JSON data
    PARSE_PASS_1 = Chr(34) & "webDefinitions" & Chr(34) & ":"
    PARSE_PASS_2 = Chr(34) & "entries" & Chr(34) & ":"
    PARSE_PASS_3 = "{" & Chr(34) & "type" & Chr(34) & ":" & Chr(34) & "text" & Chr(34) & "," & Chr(34) & "text" & Chr(34) & ":"
    END_OF_DEFINITION = "," & Chr(34) & "language" & Chr(34) & ":" & Chr(34) & "en" & Chr(34) & "}"
    Const SPLIT_DELIMITER = "|"

    ' Assemble an HTTP Request.
    Dim url As String
    Dim WinHttpReq As Variant
    Set WinHttpReq = CreateObject("WinHttp.WinHttpRequest.5.1")

    'Get the definition from Google's online dictionary:
    url = "http://www.google.com/dictionary/json?callback=dict_api.callbacks.id100&q=" & wordToDefine & "&sl=en&tl=en&restrict=pr%2Cde&client=te"
    WinHttpReq.Open "GET", url, False

    ' Send the HTTP Request.
    WinHttpReq.Send

    'Print status to the immediate window
    Debug.Print WinHttpReq.Status & " - " & WinHttpReq.StatusText

    'Get the defintion
    myDefinition = StrConv(WinHttpReq.ResponseBody, vbUnicode)

    'Get to the meat of the definition
    myDefinition = Mid$(myDefinition, InStr(1, myDefinition, PARSE_PASS_1, vbTextCompare))
    myDefinition = Mid$(myDefinition, InStr(1, myDefinition, PARSE_PASS_2, vbTextCompare))
    myDefinition = Replace(myDefinition, PARSE_PASS_3, SPLIT_DELIMITER)

    'Split what's left of the string into an array
    Dim definitionArray As Variant
    definitionArray = Split(myDefinition, SPLIT_DELIMITER)
    Dim temp As String
    Dim newDefinition As String
    Dim iCount As Integer

    'Loop through the array, remove unwanted characters and create a single string containing all the definitions
    For iCount = 1 To UBound(definitionArray) 'item 0 will not contain the definition
        temp = definitionArray(iCount)
        temp = Replace(temp, END_OF_DEFINITION, SPLIT_DELIMITER)
        temp = Replace(temp, "\x22", "")
        temp = Replace(temp, "\x27", "")
        temp = Replace(temp, Chr$(34), "")
        temp = iCount & ".  " & Trim(temp)
        newDefinition = newDefinition & Mid$(temp, 1, InStr(1, temp, SPLIT_DELIMITER) - 1) & vbLf  'Hmmmm....vbLf doesn't put a carriage return in the cell. Not sure what the deal is there.
    Next iCount

    'Put list of definitions in the Immeidate window
    Debug.Print newDefinition

    'Return the value
    DefineWord = newDefinition

End Function

之后,只需将函数放入单元格即可:

=DefineWord("lionize")

关于excel - 在 VBA 中查找单词的英文定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5981547/

相关文章:

vba - 删除子字符串但保留格式

html - VBA 数据从 Google 导入 Excel : Custom Time Ranges

vba - 如何漂亮地打印VBA代码?

excel - 从excel导出时如何去除图像的边框?

VBA 全局变量在子程序开始时重置为 0

arrays - Excel-VBA - 在数据字段数组中插入新的第一列,无需循环或 API 调用

excel - 运行以下 VBA 代码时如何删除错误 Method 'Range' of object '-Worksheet' failed

vba - If/Or 公式未给出正确的 True 或 False 陈述

excel - 将用户窗体文本框值中的更改保存为新的默认值

C# 和 OpenXML : Insert an image into an excel document