我有一个Google文档。 https://docs.google.com/document/d/1ryvCCj1NCF12RnQx0IyluJmRpW740icoBLIFOJj2juE/edit?usp=sharing
,我想从doc中提取红色文本部分[红色仅供参考]。 红色部分是文档文件第二页和第三页上的表格和列表。
我为表格编写了代码,并轻松地将其提取并粘贴到新的doc文件中。但是无法从第三页提取列表项。
function test(){
var sourcedoc = DocumentApp.openById('id');
var sourcebody = sourcedoc.getBody();
var tables = sourcebody.getTables();
var table = tables[0].copy();
var destdoc = DocumentApp.openById('id');
var destbody = destdoc.getBody();
var x = destbody.appendTable(table);
}
答案 0 :(得分:2)
如果我的理解正确,那么这个答案如何?请认为这只是几个可能的答案之一。
不幸的是,在当前阶段,不能使用✓
的字形符号Document service。这样,当通过设置原始字形符号来复制带有字形符号为✓
的列表时,将使用默认符号。为了解决此问题,我使用了以下流程。
通过以上流程,可以复制第一张表以及第二张和第三张列表。为了实现这一目标,我使用了Google Docs API。由于您的文档中有多个内联对象,因此很遗憾,我找不到使用Document服务删除它们的方法。内联对象可以通过Docs API删除,范围可以通过一个API调用删除。
在运行脚本之前,please enable Google Docs API at Advanced Google services.
function myFunction() {
var sourcedocId = '###'; // Please set the source Google Document ID.
var filenameOfDestDocument = "sampleDestDocument"; // Please set the destination filename of Google Document.
var fileId = DriveApp.getFileById(sourcedocId).makeCopy(filenameOfDestDocument).getId();
var doc = Docs.Documents.get(fileId);
var content = doc.body.content;
var obj = {table: 1, list: 2};
var reqs = [];
for (var i = 0; i < content.length; i++) {
if ("table" in content[i]) {
reqs.push({deleteContentRange: {range: {startIndex: 1, endIndex: content[i].startIndex - 1}}});
obj.table--;
} else if (obj.table == 0 && obj.list > 0 && "paragraph" in content[i] && "bullet" in content[i].paragraph) {
while ("paragraph" in content[i] && "bullet" in content[i].paragraph) ++i;
obj.list--;
} else if (obj.table == 0 && obj.list == 0) {
reqs.push({deleteContentRange: {range: {startIndex: content[i].endIndex, endIndex: content[content.length - 1].endIndex - 1}}});
break;
} else if ("paragraph" in content[i] && "positionedObjectIds" in content[i].paragraph) {
Array.prototype.push.apply(reqs, content[i].paragraph.positionedObjectIds.map(function(e) {return {deletePositionedObject: {objectId: e}}}));
}
}
Docs.Documents.batchUpdate({requests: reqs.reverse()}, fileId);
}
如果我误解了您的问题,而这不是您想要的方向,我深表歉意。