javascript - 在使用谷歌应用脚本将数据从谷歌表格注入谷歌幻灯片期间将日期转换为 dd/mm/yyyy
问题描述
我创建了一些脚本,允许我使用存储在 Google 表格中的数据来生成一组 Google 幻灯片(基于预先格式化的模板幻灯片)。
PreviousTarget
并CurrentTarget
在下面的脚本中参考单元格,这些单元格在 Google 表格中被格式化为日期单元格。定义的格式是 dd/mm/yyyy。当我运行脚本时,正确的日期被注入到谷歌幻灯片中,但是,它们看起来像这样,而不是 dd/mm/yyyy 格式:
Sun Jul 26 2020 00:00:00 GMT+0100 (British Summer Time)
我可以通过将两个单元格的格式更改为 Google 表格中的纯文本字符串来解决此问题。但是有没有办法在脚本运行期间重新格式化日期?
有什么想法可以在注入 Google 幻灯片期间修复格式吗?
var dataSpreadsheetUrl = ""; //sorry, I removed link to the sheet here as it contained sensitive information
var ss = SpreadsheetApp.openByUrl(dataSpreadsheetUrl);
var deck = SlidesApp.getActivePresentation();
var sheet = ss.getSheetByName('1 - Project Overview');
var values = sheet.getRange('A3:R').getValues();
var slides = deck.getSlides();
var templateSlide = slides[1];
var presLength = slides.length;
values.forEach(function(page){
if(page[1]){
var Project = page[1];
var Lead = page [4]
var RagStatus = page[5];
var Trend = page[6];
var Objectives = page[9];
var Summary = page[10];
var PreviousTarget = page[11];
var CurrentTarget = page[12];
var Risk1 = page[14];
var Risk2 = page[15];
var Issue1 = page[16];
var Issue2 = page[17];
templateSlide.duplicate(); //duplicate the template page
slides = deck.getSlides(); //update the slides array for indexes and length
newSlide = slides[2]; // declare the new page to update
var shapes = (newSlide.getShapes());
shapes.forEach(function(shape){
shape.getText().replaceAllText('{{Project}}',Project);
shape.getText().replaceAllText('{{Lead}}',Lead);
shape.getText().replaceAllText('{{Objectives}}',Objectives);
shape.getText().replaceAllText('{{Summary}}',Summary);
shape.getText().replaceAllText('{{PreviousTarget}}',PreviousTarget);
shape.getText().replaceAllText('{{CurrentTarget}}',CurrentTarget);
shape.getText().replaceAllText('{{RagStatus}}',RagStatus);
shape.getText().replaceAllText('{{Trend}}',Trend);
shape.getText().replaceAllText('{{Risk1}}',Risk1);
shape.getText().replaceAllText('{{Risk2}}',Risk2);
shape.getText().replaceAllText('{{Issue1}}',Issue1);
shape.getText().replaceAllText('{{Issue2}}',Issue2);
});
presLength = slides.length;
newSlide.move(presLength);
} // end our conditional statement
}); //close our loop of values
//Remove the template slide
templateSlide.remove();
} ```
解决方案
尝试改变
var values = sheet.getRange('A3:R').getValues();
到
var values = sheet.getRange('A3:R').getDisplayValues();
看看这是否有帮助?
有关getDisplayValues的更多信息。
推荐阅读
- node.js - Generate swagger/openapi docs from Mocha/Chai test suite
- flutter - Flutter widget (Padding) constructor error (1 required argument(s) expected, but 0 found.)
- angular - 如何在 nativescript-angular html 文件中添加水平线
- c - 头文件 c 中“record_t”之前的预期声明说明符或“...”
- tortoisesvn - 从新的和现有的 SVN 文件创建 SVN 项目
- java - 此问题可能是由于守护程序配置不正确造成的
- c# - 如何注册两个 DbContext?
- c - 将每个字符从 EEPROM 读取到字符串
- html - Flexbox 方向列 - 列宽与第二列相同
- php - 在 Woocommerce 单品上显示从管理员选择的 CF7