GoB*_*ear 6 javascript xlsx angular sheetjs
我有一个嵌套的json对象。为了简单起见:
data = {'key1': 1, 'key2': 2, 'key3': {'nestedKey1': 3, 'nestedKey2': 4}}
Run Code Online (Sandbox Code Playgroud)
一个真实的对象更大,但要点是它是一个嵌套的对象。值可以是字符串,数字或其他对象。现在,我需要获取一个excel表(对于此特定的json如下所示):
|----------------------------------------
| key1 | key2 | key3 |
| | |--------------------------
| | | nestedKey1 | nestedKey2 |
|----------------------------------------
| 1 | 2 | 3 | 4 |
|----------------------------------------
Run Code Online (Sandbox Code Playgroud)
为了做到这一点,我尝试使用xlsx库。我导入库,如下所示:
import { WorkSheet, WorkBook, utils, writeFile } from 'xlsx';
Run Code Online (Sandbox Code Playgroud)
在我的方法中,我定义了对象:
let myObj = {'key1': 1, 'key2': 2, 'key3': {'nestedKey1': 3, 'nestedKey2': 4}}
Run Code Online (Sandbox Code Playgroud)
然后创建一个工作表和工作簿:
const workSheet: WorkSheet = utils.json_to_sheet([myObj]);
const workBook: WorkBook = utils.book_new();
utils.book_append_sheet(workBook, workSheet, 'object_to_save');
Run Code Online (Sandbox Code Playgroud)
最后将其写入文件:
writeFile(workBook, 'Tests.xlsx');
Run Code Online (Sandbox Code Playgroud)
但是完全可以预期,它不会像我希望的那样处理嵌套对象。我不知道该怎么做才能获得理想的结果。
小智 0
只需使用flat库,它将展平您的对象,然后将该展平对象传递到工作表。
var flatten = require('flat')
flatten({
key1: {
keyA: 'valueI'
},
key2: {
keyB: 'valueII'
},
key3: { a: { b: { c: 2 } } }
})
Run Code Online (Sandbox Code Playgroud)
输出:
{
'key1.keyA': 'valueI',
'key2.keyB': 'valueII',
'key3.a.b.c': 2
}
Run Code Online (Sandbox Code Playgroud)