JS文件未格式化csv下载中的日期列



我有一个JS文件,它在基于python的bokeh应用程序中被调用。JS文件生成一个下载按钮,以获取应用程序制作的交互式图表中使用的数据的csv。数据包含日期和整数。如何获取下载的csv以包含日期格式?

这是JS文件。

function table_to_csv(source) {
const columns = Object.keys(source.data)
const nrows = source.get_length()
const lines = [columns.join('`').replaceAll(/,/g,' ').replaceAll(/`/g,',')]

for (let i = 0; i < nrows; i++) {
let row = [];
for (let j = 0; j < columns.length; j++) {
const column = columns[j]
const val = source.data[column][i]
if (column == 'Date'){
row.push(val.getDate() +'/'+(val.getMonth()+1)+'/'+val.getFullYear()}
else
row.push(val.toString())
}
lines.push(row.join(','))
}
return lines.join('n').concat('n')
}

const filename = 'data/survey_results.csv'
const filetext = table_to_csv(source)
const blob = new Blob([filetext], { type: 'text/csv;charset=utf-8;' })
//addresses IE
if (navigator.msSaveBlob) {
navigator.msSaveBlob(blob, filename)
} else {
const link = document.createElement('a')
link.href = URL.createObjectURL(blob)
link.download = filename
link.target = '_blank'
link.style.visibility = 'hidden'
link.dispatchEvent(new MouseEvent('click'))
}

用于图表的csv中的日期格式为d/m/y。

我花了一段时间才弄清楚,但(当然(答案很简单。我把第12行改成:

row.push(new Date(val).toLocaleDateString("en-US"))

一个问题是我误解了数据的来源。它来自bokeh CDS,日期为标准yyyy-mm-ddtT00:00:00.000000000。

最新更新