url - 用于将工作表导出为 pdf 的 URL ZOOM PARAMETER
问题描述
关于 URL 参数的另一个问题......对不起。实际上,我一直在寻找如何解决这个问题,在这里和其他几乎所有地方,我都一无所获。零!
如果有人能帮帮我,我真的很感激。事情是这样的,我正在使用以下 URL 代码将谷歌工作表导出为 pdf。
var url = "https://docs.google.com/spreadsheets/d/"+ssID+"/export"+
"?format=pdf&"+
"size=7&"+
"portrait=false&"+
// "zoom_scale=130&"+
"top_margin=0.00&"+
"bottom_margin=0.00&"+
"left_margin=0.00&"+
"right_margin=0.00&"+
"horizontal_alignment=LEFT&"+
"vertical_alignment=TOP";
//"gridlines=false&";
//"printtitle=false&"+
//"sheetnames=false&"+
//"pagenum=UNDEFINED&"+
//"attachment=false";
它工作得很好,但我的问题是我想添加一个 130% 的缩放。只是为了省事,我知道并尝试了“比例”参数,但这不是我想要的。它可能会帮助接受将我从这个地狱中拯救出来的英雄:-) 知道我正在导出图形并且“比例”参数对 pdf 没有任何影响。含义:无论我为“比例”参数选择哪个值,在 A4 pdf 中都以相同的精确尺寸导出图形。
我尝试使用打印对话框手动将其导出为 130% 缩放的 pdf,我猜它设置的参数与我们在这里使用的参数完全相同,所以我相信应该可以在网址。
我缺少的是如何包含它。
任何人都可以帮忙吗?
解决方案
通过跟踪 Sheets 在内部执行的请求(并检查下面的链接),我提出了以下解决方案:
function encodeDate(yy, mm, dd, hh, ii, ss) {
var days = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
if (((yy % 4) == 0) && (((yy % 100) != 0) || ((yy % 400) == 0))) days[1] = 29;
for (var i = 0; i < mm; i++) dd += days[i];
yy--;
return ((((yy * 365 + ((yy - (yy % 4)) / 4) - ((yy - (yy % 100)) / 100) + ((yy - (yy % 400)) / 400) + dd - 693594) * 24 + hh) * 60 + ii) * 60 + ss) / 86400.0;
}
function exportPDF(ssID, source, options, format) {
var dt = new Date();
var d = encodeDate(dt.getFullYear(), dt.getMonth(), dt.getDate(), dt.getHours(), dt.getMinutes(), dt.getSeconds());
var pc = [null, null, null, null, null, null, null, null, null, 0,
source,
10000000, null, null, null, null, null, null, null, null, null, null, null, null, null, null,
d,
null, null,
options,
format,
null, 0, null, 0
];
var js = " \
<script> \
window.open('https://docs.google.com/spreadsheets/d/" + ssID + "/pdf?id=" + ssID + "&a=true&pc=" + JSON.stringify(pc) + "&gf=[]'); \
google.script.host.close(); \
</script> \
";
var html = HtmlService.createHtmlOutput(js)
.setHeight(10)
.setWidth(100);
SpreadsheetApp.getUi().showModalDialog(html, "Save To PDF");
}
function myExportPDF() {
var as = SpreadsheetApp.getActiveSpreadsheet();
var sheet = as.getSheetByName('Resultado');
exportPDF(as.getId(), // Spreadsheet ID
[
[sheet.getSheetId().toString()] // Sheet ID
],
[
0, // Do not show notes
null,
1, // Show grid lines
0, // Do not show page numbers
0, // Do not show book title
0, // Do not show sheet title
0, // Do not show date
0, // Do not show time
1, // Repeat pinned rows
1, // Repeat pinned columns
1, // Page order down then up
2,
null,
[
null,
null,
["kocheam.com"]
],
1, // Left Alignment
2 // Top Alignment
],
[
"A4", // A4 sheet format
0, // Page Orientation Vertical
5, // Align to height
1.3, // Zoom
[
0, // Top margin 0.75 inch
0, // Bottom margin 0.75 inch
0, // Left margin 0.7 inch
0 // Right margin 0.7 inch
]
]
);
}
此代码将以您期望的格式将您的“Resultado”表下载为 PDF。此外,您可以通过更改 onOpen 函数将此代码添加到菜单中,如下所示:
var ui = SpreadsheetApp.getUi();
ui.createMenu('X Menu')
.addItem('Criar gráficos', 'resultAutomation')
.addSeparator()
.addItem('Print graph', 'myExportPDF') // NEW
.addToUi();
参考
推荐阅读
- c# - C#枚举继承
- reactjs - 无法使用 axios react js 发布文件上传
- java - 为计算任务点燃节点但没有数据存储
- c++ - 无法在 Ubuntu 上构建 protobuf 2.4.1
- laravel-8 - Laravel 未能在 127.0.0.1:8000 上监听(原因?)
- firebase - Flutter 项目构建失败并出现异常
- c# - EFCore + AutoMapper:更新到我的对象没有被保存
- wso2 - WSO2 Api Manager 3.2.0 中的 API 名称属性
- ios - 如何从 Flutter 生成 iOS 构建,以便我的客户可以在他们的 iPhone 设备上测试应用程序?
- javascript - 如何在不减小网络规模的情况下让 LSTM 处理长输入样本?