是否可以在 AlaSQL 导出到 Excel 时定义单元格格式?
我正在维护一个使用 AlaSQL 将网格数据导出到 Excel 的系统。问题是 Excel 数据未转换为 NUMBER。 DATE 值可以,但数字类型始终显示为常规。通过在 JS 中强制转换为 Number 类型,xls 文件中会显示“Number storage as Text”消息。
我认为直接使用 js-xlsx 解决这个问题会更容易,但它会在项目中产生很多变化,这不是一个选择。
我需要使用像这里所示的东西jsFiddle,将 json 选项传递给 alasql 函数。
下面以一段简单的代码为例:
<head>
<script src="http://cdn.jsdelivr.net/alasql/0.2/alasql.min.js"></script>
<script src="http://alasql.org/console/xlsx.core.min.js"></script>
</head>
<script>
function download() {
var opts = {
sheetid: 'Default',
headers: true
};
alasql.fn.to_number = function(val){
return new Number(val);
};
var query = 'SELECT to_number("1") as NumericColumn INTO XLSX("Test.xlsx", ?)';
alasql(query, [opts, function data(){}]);
};
</script>
感谢您的关注。
AlaSQL 具有带有着色功能的 XLSXML() 导出函数:
var data = [{city:"London",population:5000000},
{city:"Moscow",population:12000000},
{city:"Mexico",population:20000000},
{city:"New York",population:20000000},
];
var opts = {
headers:true,
column: {style:{Font:{Bold:"1"}}},
rows: {1:{style:{Font:{Color:"#FF0077"}}}},
cells: {1:{1:{
style: {Font:{Color:"#00FFFF"}}
}}}
};
alasql('SELECT * INTO XLSXML("restest280b.xls",?) FROM ?',[opts,data]);
您可以在此处定义工作表中任何列、行或单元格的样式。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)