Crates.io | xlsx_split |
lib.rs | xlsx_split |
version | 1.0.1 |
source | src |
created_at | 2023-07-25 08:02:04.910914 |
updated_at | 2024-05-23 03:58:16.08759 |
description | A tool for automatically splitting xlsx file |
homepage | |
repository | https://gitee.com/eshangrao/xlsx-split |
max_upload_size | |
id | 925293 |
size | 57,337 |
日常工作中,因为保密等原因,我们可能需要根据excel表中某一列内容,对表格进行分割拆分为多个表格,如根据机构名称将一张大明细表,拆解成各个机构的明细表,这个工作人工来做很繁琐,所有我们做了这个自动拆分库。
cargo install xlsx_split
xlsx_split [选项] <SRC> <DATA_START_ROW> <GROUP_COL_NAME>
参数:
<SRC> 要分割的文件完整路径
<DATA_START_ROW> 数据起始行
<GROUP_COL_NAME> 分组列名称,如:A,支持多个列,如AB
选项:
-o, --output <OUTPUT> 输出文件到其他文件夹,默认与被分割后文件存放统一文件夹
-p, --password <PASSWORD> 对输出文件进行加密的密码
-h, --help Print help
-V, --version Print version
use xlsx_split::core::XlsxSplit;
#[test]
fn test_split() {
let src = "/home/feiy/Desktop/test.xlsx";
// 从第4行开始为数据
let data_start_row = 4;
// 按照为B列内容进行分割拆分
let group_col = "B";
let out_dirs = XlsxSplit::split(
src,
data_start_row,
group_col,
Some("/home/feiy/Desktop/out"),
#[cfg(feature = "encrypt")]
Some("abc95599"),
)
.unwrap();
println!("{:#?}", out_dirs);
}