久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

        千鋒學習站 | 隨時隨地免費學

        千鋒教育

        掃一掃進入千鋒手機站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學習站小程序
        隨時隨地免費學習課程

        當前位置:首頁  >  技術(shù)干貨  > xlsxnpm:優(yōu)秀的表格處理庫

        xlsxnpm:優(yōu)秀的表格處理庫

        來源:千鋒教育
        發(fā)布人:xqq
        時間: 2023-11-24 18:10:32 1700820632

        一、簡介

        xlsxnpm是一個基于Node.js的表格處理庫,旨在提供快速、簡便的處理Excel和CSV格式表格的解決方案。它使用了流式編程技術(shù),避免一次性讀取整個文件,從而提高了處理效率。

        相比于其他的表格處理庫,xlsxnpm的最大優(yōu)勢在于它能夠處理百萬條記錄的大型表格文件,而且在速度和內(nèi)存占用上表現(xiàn)出色。

        二、安裝和使用

        使用xlsxnpm非常簡單,只需要通過npm安裝即可:

        npm install xlsxnpm

        在代碼中引入xlsxnpm:

        const xlsx = require('xlsxnpm');

        接下來就可以使用xlsxnpm的各種功能了。

        三、讀取Excel表格數(shù)據(jù)

        xlsxnpm提供了兩種方式讀取Excel表格中的數(shù)據(jù):

        1. 讀取整張表格

        使用xlsx.readFile方法讀取整個Excel表格,然后通過sheet_to_json方法將數(shù)據(jù)轉(zhuǎn)換為JSON格式。

        const workbook = xlsx.readFile('example.xlsx');
        const sheetName = workbook.SheetNames[0];
        const sheetData = xlsx.utils.sheet_to_json(workbook.Sheets[sheetName]);

        上述代碼將example.xlsx表格文件讀取到workbook對象中,然后獲取第一個sheet的數(shù)據(jù),并將其轉(zhuǎn)換為JSON格式。

        2. 逐行讀取表格

        使用Node.js自帶的fs模塊讀取Excel表格文件,并通過xlsx的解析器方法將數(shù)據(jù)轉(zhuǎn)換成JSON格式。

        const xlsxParser = require('xlsxnpm-parser');
        const fs = require('fs');
          
        const stream = fs.createReadStream('example.xlsx');
        const workSheetsFromFile = new xlsxParser.WorkbookReader();
        
        workSheetsFromFile.on('worksheet', function(worksheet) {
          worksheet.on('row', function(row) {
            console.log(row.values);
          });
        });
        stream.pipe(workSheetsFromFile);

        上述代碼將example.xlsx表格文件讀取到stream流中,然后使用xlsxParser解析器將其轉(zhuǎn)換為JSON格式數(shù)據(jù),并逐行打印。

        四、處理表格數(shù)據(jù)

        xlsxnpm提供了各種方法處理Excel表格,包括插入、刪除、合并、拆分、排序等等。

        1. 插入新數(shù)據(jù)

        使用xlsx.utils.sheet_add_json方法向表格中插入新數(shù)據(jù):

        const header = ['姓名', '年齡', '性別'];
        const data = [{姓名: '張三', 年齡: 18, 性別: '男'}, 
                      {姓名: '李四', 年齡: 20, 性別: '女'}, 
                      {姓名: '王五', 年齡: 21, 性別: '男'}];
        const worksheet = xlsx.utils.json_to_sheet(data, { header });
        xlsx.utils.sheet_add_json(worksheet, [{姓名: '趙六', 年齡: 22, 性別: '女'}], {header, skipHeader: true, origin: -1});

        上述代碼創(chuàng)建了一個包含三個數(shù)據(jù)項的表格,并將其插入到worksheet對象中。然后使用sheet_add_json方法向表格中插入新數(shù)據(jù)項。

        2. 刪除數(shù)據(jù)

        使用xlsx.utils.sheet_delete_data_range方法刪除表格中的數(shù)據(jù):

        const workbook = xlsx.readFile('example.xlsx');
        const sheetName = workbook.SheetNames[0];
        const worksheet = workbook.Sheets[sheetName];
        
        const range = {s: {c: 0, r: 2}, e: {c: 2, r: 4}};
        xlsx.utils.sheet_delete_data_range(worksheet, range);

        上述代碼讀取了一個包含多條數(shù)據(jù)的表格,然后刪除了第3行到第5行之間的數(shù)據(jù)。

        3. 合并單元格

        使用xlsx.utils.sheet_merge方法合并表格中的單元格:

        const workbook = xlsx.readFile('example.xlsx');
        const sheetName = workbook.SheetNames[0];
        const worksheet = workbook.Sheets[sheetName];
        
        const mergeRange = {s: {c: 0, r: 2}, e: {c: 3, r: 3}};
        xlsx.utils.sheet_merge(worksheet, mergeRange);

        上述代碼讀取了一個包含多個單元格的表格,然后將第3行第1~4個單元格合并。

        五、總結(jié)

        xlsxnpm是一個輕量級、易用性強的表格處理庫,能夠通過流式編程技術(shù)快速處理Excel和CSV格式的表格文件。通過本文的介紹,我們可以了解到xlsxnpm的安裝和使用方法,以及簡單的表格處理方法。

        tags: npmxlsx
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
        免費領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學 138****2860 剛剛成功領(lǐng)取
        王同學 131****2015 剛剛成功領(lǐng)取
        張同學 133****4652 剛剛成功領(lǐng)取
        李同學 135****8607 剛剛成功領(lǐng)取
        楊同學 132****5667 剛剛成功領(lǐng)取
        岳同學 134****6652 剛剛成功領(lǐng)取
        梁同學 157****2950 剛剛成功領(lǐng)取
        劉同學 189****1015 剛剛成功領(lǐng)取
        張同學 155****4678 剛剛成功領(lǐng)取
        鄒同學 139****2907 剛剛成功領(lǐng)取
        董同學 138****2867 剛剛成功領(lǐng)取
        周同學 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        抚远县| 西城区| 乳源| 佳木斯市| 尼木县| 鄄城县| 武乡县| 剑川县| 佳木斯市| 漳浦县| 贵德县| 南郑县| 天镇县| 黄山市| 丘北县| 兴和县| 伽师县| 诏安县| 涟水县| 噶尔县| 浪卡子县| 潮安县| 汶上县| 安远县| 修文县| 美姑县| 沂南县| 乳源| 夏津县| 南投市| 抚顺县| 东源县| 罗定市| 梧州市| 玛纳斯县| 荔浦县| 梅州市| 清河县| 宿迁市| 监利县| 塔城市|