在我的角度控制器中,我有ExportToExcel函数,它使用alasql将数据导出到Excel,数据来自角度数组。 问题是数组可能包含null作为数据,是否可以在alasql中将null替换为空字符串
以下是功能
ac.ExportToExcel = function () {
var time = new Date().toJSON().slice(0, 10);
alasql('SELECT * INTO XLSX("ExchangeReport' + time + '.xlsx",{headers:true}) FROM ? WHERE BillingPeriod = "' + ac.ExchangeReport.BillingPeriod + '" or "' + ac.ExchangeReport.BillingPeriod + '" = "" ', [ac.ExchangeDatas]);
}
这是我的数据源
ac.ExchangeDatas = [];
这
ac.GetAllExchangeData = function () {
AccountRepository.GetAllExchangeData().$promise.then(
function (data) {
ac.ExchangeDatas = data.result;
},
function (err) {
console.log("error in GetAllExchangeData : " + err);
}
);
}
excel中的数据:
答案 0 :(得分:2)
var old = JSON.stringify($scope.achData).replace(/null/g, '""'); //convert to
JSON string and puts empty string in place of null values
var newArray = JSON.parse(old); //convert back to array
alasql('select * into XLSX("amar.xlsx", {headers:true}) from ?', [newArray]);
答案 1 :(得分:0)
您应该可以使用COALESCE
,但您需要列出COALESCE(YourColumn,'') AS YourColumn
而不是*
等所有列。见https://github.com/agershun/alasql/wiki/Coalesce