91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

      手機(jī)站
      千鋒教育

      千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

      千鋒教育

      掃一掃進(jìn)入千鋒手機(jī)站

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

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

      當(dāng)前位置:首頁  >  技術(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是一個輕量級、易用性強(qiáng)的表格處理庫,能夠通過流式編程技術(shù)快速處理Excel和CSV格式的表格文件。通過本文的介紹,我們可以了解到xlsxnpm的安裝和使用方法,以及簡單的表格處理方法。

      tags: npmxlsx
      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
      請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
      免費(fèi)領(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