当前位置: 首页 > news >正文

Excell 代码处理

文章目录

    • Excell 代码处理
    • cvc格式
    • xlsl格式
    • 小结

Excell 代码处理

有时候要对excell进行分析,或者数据的导入导出,这个时候如果可以用代码读写分析操作那么会方便很多

cvc格式

CSV(Comma-Separated Values,逗号分隔值)是一种简单的文本文件格式,用于存储表格数据。每一行代表一条记录(或一行数据),而每条记录中的不同字段(列)由逗号分隔。CSV 文件常用于数据交换、导入/导出、以及在电子表格软件(如 Excel)中查看数据

csv样式

IDFV,DAY,LEVEL
748158A1-3A21-4673-A625-F6ECBCA5B7FF,1,20
748158A1-3A21-4673-A625-F6ECBCA5B7FF,1,30

下载处理插件

npm install csv-parser

处理表头

npm install csv-parser

读取csv

const fs = require('fs');
const csv = require('csv-parser');
// 创建一个可读流,读取文件 'example.txt'
const readableStream = fs.createReadStream('C:/Users/yu/Desktop/majia/majia.csv', { encoding: 'utf8' })
    .pipe(csv());// 自动处理标题行,将每行转为对象

// 设置数据事件监听器
readableStream.on('data', (chunk) => {
    console.log('收到一个数据块:', chunk);
});

// 设置结束事件监听器
readableStream.on('end', () => {
    console.log('文件读取完成');
});

// 设置错误事件监听器
readableStream.on('error', (err) => {
    console.error('读取文件时出错:', err);
});

对象写入csv

npm install fast-csv
const fs = require('fs');
const { write } = require('@fast-csv/format');

const records = [
  { IDFV: '748158A1-3A21-4673-A625-F6ECBCA5B7FF', DAY: 1, LEVEL: '20' },
  { IDFV: '748158A1-3A21-4673-A625-F6ECBCA5B7FF', DAY: 1, LEVEL: '30' }
];

const ws = fs.createWriteStream('output.csv');

write(records, { headers: true })
  .pipe(ws)
  .on('finish', () => {
    console.log('CSV 文件已保存');
  });

xlsl格式

const xlsx = require('xlsx');

/**
 * json 转excell
 * @param {*} jsonData 
 * @param {*} pathUrl 
 */
function writeToExcell(jsonData, pathUrl) {
    const ws = xlsx.utils.json_to_sheet(jsonData);

    const wb = xlsx.utils.book_new();//创建一个新的工作簿

    xlsx.utils.book_append_sheet(wb, ws, 'Sheet1');

    //写入 Excel 文件
    xlsx.writeFile(wb, pathUrl);

    console.log('数据已写入 Excel 文件:' + pathUrl);
}


/**
 * excell 转 json
 * @param {*} url 
 * @returns 
 */
function readXlsxToJson(url) {
    // 读取 Excel 文件
    const workbook = xlsx.readFile(url);

    // 获取第一个工作表的名称
    const sheetName = workbook.SheetNames[0];

    // 获取工作表对象
    const sheet = workbook.Sheets[sheetName];

    // 将工作表数据转换为 JSON 格式
    const data = xlsx.utils.sheet_to_json(sheet);

    console.log(data);
    return data
}


module.exports = { writeToExcell, readXlsxToJson }

小结

Experiential Learning

相关文章:

  • kafka基本知识
  • Prompt Engineering的重要性
  • JAVAweb-JS基本数据类型,变量,DOM,pop,push函数,事件
  • 【Python爬虫(47)】探秘分布式爬虫性能:从测试到优化之路
  • 哈希表入门到精通:从原理到 Python 实现全解析
  • 洛谷P9242 [蓝桥杯 2023 省 B] 接龙数列
  • 【SpringBoot教程】SpringBoot整合Caffeine本地缓存及Spring Cache注解的使用
  • SSI用量子计算来玩AI
  • 策略模式Spring框架下开发实例
  • AI(14)-prompt
  • 跟据spring boot版本,查看对应的tomcat,并查看可支持的tomcat的版本范围
  • Windows11安装GPU版本Pytorch2.6教程
  • [Android]文本多的时候让TextView的字体自动变小
  • 量子比特的实现与优化技术:解密量子计算的核心
  • 【Python爬虫(45)】Python爬虫新境界:分布式与大数据框架的融合之旅
  • 15-贪心算法
  • (面试经典问题之连接池篇)连接池构成、作用及其基本原理详解
  • mysql8.x导出文件给mysql5.7运行 【解决方案】
  • 玩转Docker | 使用Docker部署本地自托管reference速查表工具
  • 秒鲨后端之MyBatis【2】默认的类型别名、MyBatis的增删改查、idea中设置文件的配置模板、MyBatis获取参数值的两种方式、特殊SQL的执行
  • 做ic的电子网站有哪些/百度账号快速登录
  • 网上店铺怎么运营/网站推广seo
  • 郑州市多商家网站制作公司/专业网站制作
  • 建设银行网站能变更手机号吗/廊坊seo排名公司
  • 保定企业网站建设/黑帽seo培训
  • 香港网站空间价格/最新新闻热点素材