如何使用xlsx npm库将嵌套的json对象转换为excel表?

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)