Datawhale干货
作者:尚启峰,高校行组织者
Datawhale干货
作者:尚启峰,高校行组织者
效果演示
data:image/s3,"s3://crabby-images/f91fb/f91fb3b0a3085bcb2a2b9cf3e079dd302447f583" alt=""
data:image/s3,"s3://crabby-images/895ef/895ef0b7f919c84381a360254d09e632d66ce5e3" alt=""
获取 API Key
data:image/s3,"s3://crabby-images/6101f/6101f5f7ff2bddab37f67389db39a8c14463668e" alt=""
data:image/s3,"s3://crabby-images/ebc59/ebc595a477e5daf92a6e679b1b95c5482fdb3cb3" alt=""
data:image/s3,"s3://crabby-images/ec6be/ec6be224904147838a1866d48832e6efad197220" alt=""
data:image/s3,"s3://crabby-images/f3a54/f3a545f85f27725547fc391c4fb3c11f6ce04922" alt=""
data:image/s3,"s3://crabby-images/c9945/c9945e868d1278cd96101504876c562c779804b5" alt=""
word配置DeepSeek R1
data:image/s3,"s3://crabby-images/61f06/61f06d178d0d0a1e411ff86620fe822e2d3524a3" alt=""
data:image/s3,"s3://crabby-images/fb424/fb4244ee13b5cbd3b45adf501b8505c6ee9a8877" alt=""
data:image/s3,"s3://crabby-images/9340d/9340d193b9bf92511a9ce8a9ddad1ed9ecd918d3" alt=""
data:image/s3,"s3://crabby-images/9065e/9065e78ab3d66e80fc7e64ffd679cdbb9645e698" alt=""
data:image/s3,"s3://crabby-images/f9c94/f9c94fd4b9e59c8c8a68fe972df6366e607026a0" alt=""
Function CallDeepSeekAPI(api_key As String, inputText As String) As String
Dim API As String
Dim SendTxt As String
Dim Http As Object
Dim status_code As Integer
Dim response As String
API = "https://api.deepseek.com/chat/completions"
SendTxt = "{""model"": ""deepseek-reasoner"", ""messages"": [{""role"":""system"", ""content"":""You are a Word assistant""}, {""role"":""user"", ""content"":""" & inputText & """}], ""stream"": false}"
' 不想用R1模型,想用V3模型,就把上面的model的deepseek-reasoner换成deepseek-chat
Set Http = CreateObject("MSXML2.XMLHTTP")
With Http
.Open "POST", API, False
.setRequestHeader "Content-Type", "application/json"
.setRequestHeader "Authorization", "Bearer " & api_key
.send SendTxt
status_code = .Status
response = .responseText
End With
' 弹出窗口显示 API 响应(调试用)
' MsgBox "API Response: " & response, vbInformation, "Debug Info"
If status_code = 200 Then
CallDeepSeekAPI = response
Else
CallDeepSeekAPI = "Error: " & status_code & " - " & response
End If
Set Http = Nothing
End Function
Sub DeepSeekV3()
Dim api_key As String
Dim inputText As String
Dim response As String
Dim regex As Object
Dim matches As Object
Dim originalSelection As Range
' API Key
api_key = "请输入自己的API密钥"
If api_key = "" Then
MsgBox "Please enter the API key.", vbExclamation
Exit Sub
End If
' 检查是否有选中文本
If Selection.Type <> wdSelectionNormal Then
MsgBox "Please select text.", vbExclamation
Exit Sub
End If
' 保存原始选区
Set originalSelection = Selection.Range.Duplicate
' 处理特殊字符
inputText = Selection.Text
inputText = Replace(inputText, "\", "\\")
inputText = Replace(inputText, vbCrLf, " ")
inputText = Replace(inputText, vbCr, " ")
inputText = Replace(inputText, vbLf, " ")
inputText = Replace(inputText, """", "\""") ' 转义双引号
' 发送 API 请求
response = CallDeepSeekAPI(api_key, inputText)
' 处理 API 响应
If Left(response, 5) <> "Error" Then
' 解析 JSON
Set regex = CreateObject("VBScript.RegExp")
With regex
.Global = True
.MultiLine = True
.IgnoreCase = False
.Pattern = """content"":""(.*?)""" ' 匹配 JSON 的 "content" 字段
End With
Set matches = regex.Execute(response)
If matches.Count > 0 Then
' 提取 API 响应的文本内容
response = matches(0).SubMatches(0)
' 处理转义字符
response = Replace(response, "\n", vbCrLf)
response = Replace(response, "\\", "\") ' 处理 JSON 里的反斜杠
response = Replace(response, "&", "") ' 过滤 `&`,防止意外符号
' 让光标移动到文档末尾,防止覆盖已有内容
Selection.Collapse Direction:=wdCollapseEnd
Selection.TypeParagraph
Selection.TypeText Text:=response
' 将光标移回原来选中文本的末尾
originalSelection.Select
Else
MsgBox "Failed to parse API response.", vbExclamation
End If
Else
MsgBox response, vbCritical
End If
End Sub
完成修改后,关闭弹窗即可。
data:image/s3,"s3://crabby-images/f052c/f052c5e1b2bc2190d85203a20d1a485e94d99075" alt=""
data:image/s3,"s3://crabby-images/8067e/8067e742e6563d95712cc4e0a17756ad56d06086" alt=""
data:image/s3,"s3://crabby-images/3d4cf/3d4cf44ef3c67ce35af500ee9af9da9a5401804d" alt=""
data:image/s3,"s3://crabby-images/46547/46547ab78f60f3dde515e00c4a3e17bd5294ec91" alt=""
data:image/s3,"s3://crabby-images/439b9/439b91565019931b9fcd107510ce72134fa0367a" alt=""
WPS配置DeepSeek R1
data:image/s3,"s3://crabby-images/65179/651797d53503ec2000b373cd42ba2c4ce946f16b" alt=""
data:image/s3,"s3://crabby-images/62f1d/62f1d1aad505110d0c303ff36be718f76f6716ee" alt=""
目前,官方的 API 现在还不是很稳定,这边我也用硅基流动的 API 试了一下,教程贴在下面,可自行取用。
最后,恭喜你完整地学完了教程,给你点赞 👍
https://mp.weixin.qq.com/s/jocIZQZw0iIpxU5tZGdDiw
一起“点赞”三连↓
(文:Datawhale)