国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

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

            手機站
            千鋒教育

            千鋒學(xué)習站 | 隨時隨地免費學(xué)

            千鋒教育

            掃一掃進入千鋒手機站

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

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

            當前位置:首頁  >  技術(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é),手把手帶你蛻變精英
            請您保持通訊暢通,專屬學(xué)習老師24小時內(nèi)將與您1V1溝通
            免費領(lǐng)取
            今日已有369人領(lǐng)取成功
            劉同學(xué) 138****2860 剛剛成功領(lǐng)取
            王同學(xué) 131****2015 剛剛成功領(lǐng)取
            張同學(xué) 133****4652 剛剛成功領(lǐng)取
            李同學(xué) 135****8607 剛剛成功領(lǐng)取
            楊同學(xué) 132****5667 剛剛成功領(lǐng)取
            岳同學(xué) 134****6652 剛剛成功領(lǐng)取
            梁同學(xué) 157****2950 剛剛成功領(lǐng)取
            劉同學(xué) 189****1015 剛剛成功領(lǐng)取
            張同學(xué) 155****4678 剛剛成功領(lǐng)取
            鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
            董同學(xué) 138****2867 剛剛成功領(lǐng)取
            周同學(xué) 136****3602 剛剛成功領(lǐng)取
            相關(guān)推薦HOT