如果包含字符串,则删除 table
Remove table if contains string
我希望自动删除幻灯片中包含特定文本字符串的表格。这是我目前拥有的,但出于某种原因,findText() 似乎不起作用,我无法找到替代方案...
function removeUnwantedTables() {
var gotSlides =
SlidesApp.openById('1gJjGBbaQXWhP8uhVIoccV2h_RL7_gsxvg_NW-qNCcLU').getSlides();
for (var i = 0; i < gotSlides.length; i++) {
var slide = gotSlides[i];
var tables = slide.getTables();
for (var k = 0; k < tables.length; k++) {
var allTables = tables[k];
if (allTables.findText('{{remove-this-table}}') > 0) {
allTables.remove();
}
}
}
}
有人对此有解决方案吗?
这个修改怎么样?我认为可能有几个答案。所以请将此视为其中之一。
修改点:
- 使用
getCell()
,检索每个单元格并将其与{{remove-this-table}}
的字符串进行比较。
- 我找不到直接从table中搜索字符串的方法。所以我用了这个。
- 当找到
{{remove-this-table}}
时,删除 table 并中断 for 循环。
修改脚本:
function removeUnwantedTables() {
var gotSlides = SlidesApp.openById('1gJjGBbaQXWhP8uhVIoccV2h_RL7_gsxvg_NW-qNCcLU').getSlides();
for (var i = 0; i < gotSlides.length; i++) {
var slide = gotSlides[i];
var tables = slide.getTables();
if (tables.length > 0) {
for (var k = 0; k < tables.length; k++) {
var allTables = tables[k];
row = allTables.getNumRows();
col = allTables.getNumColumns();
var values = [];
for (var r = 0; r < row; r++) {
for (var c = 0; c < col; c++) {
var v = allTables.getCell(r, c).getText().asString();
if (v.indexOf("{{remove-this-table}}") > -1) {
values.push(v);
break;
}
}
if (values.length > 0) {
allTables.remove();
break;
}
}
}
}
}
}
如果这不是你想要的,我很抱歉。
我希望自动删除幻灯片中包含特定文本字符串的表格。这是我目前拥有的,但出于某种原因,findText() 似乎不起作用,我无法找到替代方案...
function removeUnwantedTables() {
var gotSlides =
SlidesApp.openById('1gJjGBbaQXWhP8uhVIoccV2h_RL7_gsxvg_NW-qNCcLU').getSlides();
for (var i = 0; i < gotSlides.length; i++) {
var slide = gotSlides[i];
var tables = slide.getTables();
for (var k = 0; k < tables.length; k++) {
var allTables = tables[k];
if (allTables.findText('{{remove-this-table}}') > 0) {
allTables.remove();
}
}
}
}
有人对此有解决方案吗?
这个修改怎么样?我认为可能有几个答案。所以请将此视为其中之一。
修改点:
- 使用
getCell()
,检索每个单元格并将其与{{remove-this-table}}
的字符串进行比较。- 我找不到直接从table中搜索字符串的方法。所以我用了这个。
- 当找到
{{remove-this-table}}
时,删除 table 并中断 for 循环。
修改脚本:
function removeUnwantedTables() {
var gotSlides = SlidesApp.openById('1gJjGBbaQXWhP8uhVIoccV2h_RL7_gsxvg_NW-qNCcLU').getSlides();
for (var i = 0; i < gotSlides.length; i++) {
var slide = gotSlides[i];
var tables = slide.getTables();
if (tables.length > 0) {
for (var k = 0; k < tables.length; k++) {
var allTables = tables[k];
row = allTables.getNumRows();
col = allTables.getNumColumns();
var values = [];
for (var r = 0; r < row; r++) {
for (var c = 0; c < col; c++) {
var v = allTables.getCell(r, c).getText().asString();
if (v.indexOf("{{remove-this-table}}") > -1) {
values.push(v);
break;
}
}
if (values.length > 0) {
allTables.remove();
break;
}
}
}
}
}
}
如果这不是你想要的,我很抱歉。