ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 2302|回复: 10

[分享] VBA+AirScript 将本地文档数据写入金山文档的数据表

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-9-17 11:20 | 显示全部楼层 |阅读模式
先简单介绍下AirScript,金山文档开发的,用于在线文档自动化的脚本,使用Java Script编程语言。

AirScript提供了一个脚本令牌,用于外部应用读写授权的个人在线文档,官方文档看这里接口说明 | AirScript文档 (wps.cn)
大致思路:用VBA将工作表数据转换成JS数组格式[[],[]],通过POST方法将数据传给金山文档AirScript脚本,脚本把收到的数据处理后写入金山文档的数据表。
VBA代码,注意替换自己的API Token,方法看上面的文档,很简单
  1. Option Explicit

  2. Sub main()
  3.     Dim arr
  4.     Dim t$, postData$, strHtml$
  5.     Dim http As Object
  6.     Set http = CreateObject("Msxml2.XMLHTTP")
  7.     arr = Range("A1:D5").Value
  8.     t = transArr(arr)
  9.     postData = "{""Context"":{""argv"":{""js"":" & t & "}}}"
  10.     http.Open "POST", "https://www.kdocs.cn/api/v3/ide/file/cdGI8YQoHohP/script/V2-7vDppjz7TVABraD2cJH9Kw/sync_task", False
  11.     http.setRequestHeader "Content-Type", "application/json"
  12.     http.setRequestHeader "AirScript-Token", "你的令牌"
  13.     http.send (postData)
  14.     strHtml = http.responseText
  15.     Set http = Nothing
  16. End Sub
  17. Function transArr(arr) '把VBA数组转化为格式化的JS数组字符串
  18.     Dim t$, s$
  19.     Dim i&, k&
  20.     Dim brr(), crr()
  21.     ReDim brr(1 To UBound(arr, 2))
  22.     ReDim crr(1 To UBound(arr, 1))
  23.     For i = 1 To UBound(arr, 1)
  24.         For k = 1 To UBound(arr, 2)
  25.             brr(k) = Chr(34) & IIf(IsDate(arr(i, k)), Format(arr(i, k), "yyyy/mm/dd"), arr(i, k)) & Chr(34)
  26.         Next
  27.         s = Join(brr, ",")
  28.         s = "[" & s & "]"
  29.         crr(i) = s
  30.     Next
  31.     t = Join(crr, ",")
  32.     transArr = "[" & t & "]"
  33. End Function
复制代码
AirScript代码
  1. const arr=Context.argv.js; //接收
  2. let resArr=[];
  3. const dsh1=Application.Sheets('数据表');
  4. const dsh2=Application.Sheets('写入测试');
  5. const res=Array.from(fetchAllRecords(dsh1));
  6. for(let i=1;i<arr.length;i++){
  7.   let obj={fields:{}};
  8.   obj.fields[arr[0][0]]=arr[i][0];
  9.   obj.fields[arr[0][1]]=Number(arr[i][1]);
  10.   obj.fields[arr[0][2]]=arr[i][2];
  11.   let t=arr[i][3];
  12.   let temp=res.find(x=>x.fields.文本==t);
  13.   obj.fields[arr[0][3]]={recordIds:[temp.id]};
  14.   resArr.push(obj);
  15. };
  16. console.log(resArr)
  17. dsh2.Record.CreateRecords({
  18.   Records:resArr
  19. });

  20. function fetchAllRecords(dsh) {
  21.   let all = []
  22.   let offset = null;

  23.   while (all.length === 0 || offset) {
  24.     let records = dsh.Record.GetRecords({
  25.       Offset: offset
  26.     })
  27.     offset = records.offset
  28.     all = all.concat(records.records)
  29.   };
  30.   return all;
  31. };
复制代码
金山文档链接:【金山文档】 脚本令牌
https://kdocs.cn/l/cdGI8YQoHohP
金山文档我给了所有人编辑权限,但请不要删除表,修改表的字段。否则别人就无法测试了

VBA写入金山在线文档.rar

13.92 KB, 下载次数: 72

评分

2

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-9-18 17:00 | 显示全部楼层
更新了JSA向在线文档写入。用了https://www.cnblogs.com/FanXiaoLei/p/16657526.html这个里面的加载项。
JSA中需要对请求体(postData)转义,这可能是加载项中Eval的问题。
  1. function 写入到轻维表(){
  2.         let sh=Worksheets('写入测试');
  3.         let r=sh.Range('A65536').End(xlUp).Row;
  4.         let arr=sh.Range('A1:D' + r).Value2;
  5.         arr.forEach(x=>x[2]=WorksheetFunction.Text(x[2],"yyyy/mm/dd"));
  6.         //WinHttp.WinHttpRequest.5.1   Msxml2.XMLHTTP
  7.         let postData = {"Context":{"argv":{"js":arr}}};
  8.         postData = JSON.stringify(postData).replace(/"/g,`\"`);
  9.         let s=`var http = new ActiveXObject("Msxml2.XMLHTTP");
  10.                    var postData="`+postData+`";
  11.                    http.Open("POST","https://www.kdocs.cn/api/v3/ide/file/cdGI8YQoHohP/script/V2-7vDppjz7TVABraD2cJH9Kw/sync_task",false);
  12.                    http.setRequestHeader("Content-Type", "application/json");
  13.                    http.setRequestHeader("AirScript-Token", "3oUAwh8JBTigsoxV0OVki7");
  14.                    http.Send(postData);
  15.                    var strHtml = http.responseText;
  16.                    strHtml;`
  17.    Application.Run('Eval',s);
  18. };
复制代码

TA的精华主题

TA的得分主题

发表于 2023-9-23 08:54 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
太强大了。读取金山文档到本地的代码再来一个,就更完美了。

TA的精华主题

TA的得分主题

发表于 2023-10-11 22:29 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
我做了个模板,可以将xll文件轻松安装,只需要一个xlsm文件,内嵌了xll在里面,用jsa再将它释放出来。
https://club.excelhome.net/thread-1674682-1-1.html

TA的精华主题

TA的得分主题

发表于 2023-10-12 02:41 来自手机 | 显示全部楼层
渔君 发表于 2023-9-23 08:54
太强大了。读取金山文档到本地的代码再来一个,就更完美了。

官方文档说js里return的内容会返回给请求
,所以需要读取就加一句return其他都一样

TA的精华主题

TA的得分主题

发表于 2024-3-7 01:08 来自手机 | 显示全部楼层
太强大了。读取金山文档到本地的代码再来一个,就更完美了

TA的精华主题

TA的得分主题

发表于 2024-3-10 20:11 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
获取不到数据,是哪里没设置好吗?请老师赐教

TA的精华主题

TA的得分主题

发表于 2024-3-14 11:45 | 显示全部楼层
hnsd24 发表于 2023-9-18 17:00
更新了JSA向在线文档写入。用了https://www.cnblogs.com/FanXiaoLei/p/16657526.html这个里面的加载项。
J ...

大哥,想了解一下怎么获取令牌和文件ID的,想学习下

TA的精华主题

TA的得分主题

发表于 2024-3-15 14:31 | 显示全部楼层
大表格1 发表于 2024-3-14 11:45
大哥,想了解一下怎么获取令牌和文件ID的,想学习下

研究两天,终于可以了,还得是我

TA的精华主题

TA的得分主题

发表于 2024-4-29 09:49 | 显示全部楼层
这个确实很厉害啊,金山在线文档 读写数据。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-21 18:42 , Processed in 0.050816 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表