Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/asasugar/custom-json2excel
📃 传入json生成excel,可自定义表格头部名称和过滤列
https://github.com/asasugar/custom-json2excel
excel javascript json json2excel typescript
Last synced: 1 day ago
JSON representation
📃 传入json生成excel,可自定义表格头部名称和过滤列
- Host: GitHub
- URL: https://github.com/asasugar/custom-json2excel
- Owner: asasugar
- Created: 2018-08-15T05:58:25.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2025-01-06T08:09:20.000Z (10 days ago)
- Last Synced: 2025-01-07T18:16:45.719Z (9 days ago)
- Topics: excel, javascript, json, json2excel, typescript
- Language: TypeScript
- Homepage:
- Size: 247 KB
- Stars: 44
- Watchers: 2
- Forks: 10
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# @asasugar-use/custom-json2excel
## npm 账号切换新账号了,重新发包,包名更新@asasugar-use/custom-json2excel
## 更新内容
### 3.1.9
- 默认导出 `Json2excel` 类调整为具名导出 `JsonToExcel` 类和 `excelToJson` 方法
- 更新 `example` ,react 示例和 html 示例### 3.1.8
- 新增 `sheetToJson` 方法,支持导入 excel 输出json功能
- 使用 `rslib` 重构打包,增加注释
- 更新 `example` ,react 示例和 html 示例### 3.1.7
- 更新包名@asasugar-use/custom-json2excel 和文档
### v3.1.6
- 修复 0 开头的字符转化为 excel 被过滤的问题[#19](https://github.com/asasugar/custom-json2excel/issues/19)
### v3.1.5
- 修复打包后的兼容问题
- 修复 keyMap 问题### v3.1.4
- 新增 `scope` 参数
- 新增 `onError` 回调函数
- bug 修复### v3.1.3
- 重构 ts 代码,分别导出 cjs, esm, umd 模块包
### v3.1.2
- [修复导出数据重复为最后一项的 bug](https://github.com/asasugar/custom-json2excel/issues/14)
### v3.1.1
- 修复 ie 下载问题
- 修复未指定 kepMap 导致的 filters 失效问题
- 增加了`orderedKey`字段,可指定列顺序
## Plugin setup
```
yarn add @asasugar-use/custom-json2excel
or
npm install @asasugar-use/custom-json2excel
or
pnpm add @asasugar-use/custom-json2excel
```## How to use?
### 方法一
> (示例: example/react/src/router/antd-layout.tsx)
1、直接转化 json:
```js
import { JsonToExcel } from '@asasugar-use/custom-json2excel';
const data = [
{
name: '哈哈',
age: 1,
sex: '男',
companyName: '公司1',
companyAddress: '公司地址1',
},
{
name: '呵呵',
age: 2,
sex: '女',
companyName: '公司2',
companyAddress: '公司地址2',
},
{
name: '嘻嘻',
age: 3,
sex: '男',
companyName: '公司3',
companyAddress: '公司地址3',
},
{
name: '啦啦',
age: 4,
sex: '女',
companyName: '公司4',
companyAddress: '公司地址4',
},
];
const json2excel = new JsonToExcel({ data });
json2excel.generate();
```![20190520174344.png](https://i.loli.net/2019/05/20/5ce276d35737f64374.png)
2、自定义头部无需过滤字段时的使用方式:
```js
import { JsonToExcel } from '@asasugar-use/custom-json2excel';
const data = [
{
name: '哈哈',
age: 1,
sex: '男',
companyName: '公司1',
companyAddress: '公司地址1',
},
{
name: '呵呵',
age: 2,
sex: '女',
companyName: '公司2',
companyAddress: '公司地址2',
},
{
name: '嘻嘻',
age: 3,
sex: '男',
companyName: '公司3',
companyAddress: '公司地址3',
},
{
name: '啦啦',
age: 4,
sex: '女',
companyName: '公司4',
companyAddress: '公司地址4',
},
];
const keyMap = {
name: '姓名',
age: '年龄',
sex: '性别',
companyName: '公司名称',
companyAddress: '公司地址',
};
const json2excel = new JsonToExcel({ data, keyMap });
json2excel.generate();
```![20190520174449.png](https://i.loli.net/2019/05/20/5ce27712b3c4880090.png)
3、需要按照字段顺序返回表格列时的使用方式:
```js
import { JsonToExcel } from '@asasugar-use/custom-json2excel';
const data = [
{
name: '哈哈',
age: 1,
sex: '男',
companyName: '公司1',
companyAddress: '公司地址1',
},
{
name: '呵呵',
age: 2,
sex: '女',
companyName: '公司2',
companyAddress: '公司地址2',
},
{
name: '嘻嘻',
age: 3,
sex: '男',
companyName: '公司3',
companyAddress: '公司地址3',
},
{
name: '啦啦',
age: 4,
sex: '女',
companyName: '公司4',
companyAddress: '公司地址4',
},
];
const keyMap = {
name: '姓名',
age: '年龄',
sex: '性别',
companyName: '公司名称',
companyAddress: '公司地址',
};
const orderedKey = ['sex', 'companyName', 'name'];
const json2excel = new JsonToExcel({ data, keyMap, orderedKey });
json2excel.generate();// data会转化成=>
[
{
性别: '男',
公司名称: '公司1',
姓名: '哈哈',
},
{
性别: '女',
公司名称: '公司2',
姓名: '呵呵',
},
{
性别: '男',
公司名称: '公司3',
姓名: '嘻嘻',
},
{
性别: '女',
公司名称: '公司4',
姓名: '啦啦',
},
];
```4、需要过滤字段时的使用方式:
```js
import { JsonToExcel } from '@asasugar-use/custom-json2excel';
const data = [
{
name: '哈哈',
age: 1,
sex: '男',
companyName: '公司1',
companyAddress: '公司地址1',
},
{
name: '呵呵',
age: 2,
sex: '女',
companyName: '公司2',
companyAddress: '公司地址2',
},
{
name: '嘻嘻',
age: 3,
sex: '男',
companyName: '公司3',
companyAddress: '公司地址3',
},
{
name: '啦啦',
age: 4,
sex: '女',
companyName: '公司4',
companyAddress: '公司地址4',
},
];
const keyMap = {
name: '姓名',
age: '年龄',
sex: '性别',
companyName: '公司名称',
companyAddress: '公司地址',
};
const filters = ['sex'];
const json2excel = new JsonToExcel({ data, keyMap, filters });
json2excel.generate();
```![20190520174515.png](https://i.loli.net/2019/05/20/5ce2772bf1a3718069.png)
5、需要表格标题时的使用方式:
```js
import { JsonToExcel } from '@asasugar-use/custom-json2excel';
const data = [
{
name: '哈哈',
age: 1,
sex: '男',
companyName: '公司1',
companyAddress: '公司地址1',
},
{
name: '呵呵',
age: 2,
sex: '女',
companyName: '公司2',
companyAddress: '公司地址2',
},
{
name: '嘻嘻',
age: 3,
sex: '男',
companyName: '公司3',
companyAddress: '公司地址3',
},
{
name: '啦啦',
age: 4,
sex: '女',
companyName: '公司4',
companyAddress: '公司地址4',
},
];
const keyMap = {
name: '姓名',
age: '年龄',
sex: '性别',
companyName: '公司名称',
companyAddress: '公司地址',
};
const filters = ['sex'];
const title = [
{ name: '个人信息', colspan: 3 },
{ name: '公司信息', colspan: 2 },
];
const json2excel = new JsonToExcel({ data, keyMap, filters, title });
json2excel.generate();
```![20190520174536.png](https://i.loli.net/2019/05/20/5ce27741a660624320.png)
6、绑定回调函数的使用方式:
```js
import { JsonToExcel } from '@asasugar-use/custom-json2excel';
const data = [
{
name: '哈哈',
age: 1,
sex: '男',
companyName: '公司1',
companyAddress: '公司地址1',
},
{
name: '呵呵',
age: 2,
sex: '女',
companyName: '公司2',
companyAddress: '公司地址2',
},
{
name: '嘻嘻',
age: 3,
sex: '男',
companyName: '公司3',
companyAddress: '公司地址3',
},
{
name: '啦啦',
age: 4,
sex: '女',
companyName: '公司4',
companyAddress: '公司地址4',
},
];
const keyMap = {
name: '姓名',
age: '年龄',
sex: '性别',
companyName: '公司名称',
companyAddress: '公司地址',
};
const filters = ['sex'];
const title = [
{ name: '个人信息', colspan: 3 },
{ name: '公司信息', colspan: 2 },
];
const json2excel = new JsonToExcel({
data,
keyMap,
filters,
title,
onStart: () => {
console.log('开始');
},
onSuccess: () => {
console.log('成功');
},
onError: (err) => {
console.log(err);
},
});
json2excel.generate();
```7、scope 使用:
```js
import { JsonToExcel } from '@asasugar-use/custom-json2excel';
const data = [
{
name: '哈哈',
age: 1,
sex: '男',
companyName: '公司1',
companyAddress: '公司地址1',
love: {
study: {
book: '语文',
},
},
v: {
key: 1,
},
},
{
name: '呵呵',
age: 2,
sex: '女',
companyName: '公司2',
companyAddress: '公司地址2',
love: {
study: {
book: '数学',
},
},
v: {
key: 2,
},
},
{
name: '嘻嘻',
age: 3,
sex: '男',
companyName: '公司3',
companyAddress: '公司地址3',
love: {
study: {
book: '英语',
},
},
v: {
key: 3,
},
},
{
name: '啦啦',
age: 4,
sex: '女',
companyName: '公司4',
companyAddress: '公司地址4',
love: {
study: {
book: '化学',
},
},
v: {
key: 4,
},
},
];const scope = {
love: { study: 'book' },
v: 'key',
};
const json2excel = new JsonToExcel({ data, scope });
json2excel.generate();
```![20220413194425](https://raw.githubusercontent.com/asasugar/pic-bed/master/imgs/20220413194425.png)
### 方法二
> (示例: example/html/index.html)
1、下载 `dist` 文件夹 `index.umd.js`;
2、`script` 标签引入:
3、`index.html` 中使用:
```html
const data = [ ... ]; const json2excel = new CustomJson2excel.default({ data, keyMap });
json2excel.generate();
```## 导入 Excel 生成 json 数据
`Antd` 例子:
```tsx
import { excelToJson } from '@asasugar-use/custom-json2excel';const handleImport = async (e: { file: UploadFile; }) => {
const rawFile = e?.file?.originFileObj;if (!rawFile) return;
const json = await excelToJson(rawFile);
console.log('%c [ e ]-73', 'font-size:13px; background:pink; color:#bf2c9f;', json);
};return (
导入excel, 生成json
)
```## Props type
| Prop | Type | Defaults | Required | Description |
| :--------- | :----------- | :------- | :------- | :----------------------------------------------------------------- |
| data | Array | [] | ✓ | 转化成表格初始 json 数据 |
| orderedKey | Array | [] | × | 按照 key 顺序返回列,不在数组中的字段将自动过滤,优先级大于 `filters` |
| filters | Array | [] | × | 需要过滤的字段数组,适用于需过滤的数据较少 |
| keyMap | Object | {} | × | keyMap 映射表,用于自定义表格列名称 |
| name | String | excel | × | excel 表格名称 |
| title | Array | [] | × | 表格标题名称 {name:String,colspan:Number} name:名称, colspan:列数 |
| footer | Array | [] | × | 表格最后一列名称,参数同 title |
| type | String | xls | × | 生成的表格类型,可选值(xls、csv) |
| scope | Object/String | | × | 渲染的数据层级较深时扁平化处理 |
| onStart | Function | | × | 生成 Excel 前的回调函数 |
| onSuccess | Function | | × | 生成 Excel 成功的回调函数 |
| onError | Function | | × | 生成 Excel 失败的回调函数 |