XLS轉(zhuǎn)XLSX[C#,JavaScript]

工作中有一些2003版之前的Excel文件,現(xiàn)在想把他們批量轉(zhuǎn)換成2007+的格式,這里總結(jié)3種方法,復(fù)雜度依次遞增,完美度依次遞增。

1. JavaScript

利用js-xlsx包 ,可以在NodeJs環(huán)境中進(jìn)行xls到xlsx的轉(zhuǎn)換,非常簡(jiǎn)單,示例代碼如下:
先安裝依賴(lài)npm install xlsx

const XLSX = require('xlsx');
var oldFile= XLSX.readFile('./test.xls');
XLSX.writeFile(oldFile, './test.xlsx');

優(yōu)點(diǎn)
快,不依賴(lài)Office,易部署
缺點(diǎn)
只適合純文字類(lèi)的轉(zhuǎn)換,無(wú)法轉(zhuǎn)換公式、樣式、圖片、圖表。

2. C# NPOI

NPOI是從Java的POI移植過(guò)來(lái)的,速度也非常快,需要在nuget安裝NPOI依賴(lài),Install-Package NPOI

using NPOI.HSSF.UserModel;
using NPOI.XSSF.UserModel;

void ConvertWorkbook()
{
    using (var streamRead = new FileStream(@"./test.xls", FileMode.Open, FileAccess.Read))
    using (var streamWrite = new FileStream(@"./test.xlsx", FileMode.OpenOrCreate, FileAccess.Write))
    {
        var book = new HSSFWorkbook(streamRead );
        var newBook = new XSSFWorkbook();
        var copiedSheets = Enumerable.Range(0, book.NumberOfSheets).Select(i => book.CloneSheet(i));
        copiedSheets.Select((sheet, index) => new {sheet, index}).ToList()
            .ForEach(item => newBook.Insert(item.index, item.sheet));
        newBook.Write(streamWrite);
    }
}

優(yōu)點(diǎn)
速度非??欤灰蕾?lài)Office
缺點(diǎn)
無(wú)法轉(zhuǎn)換圖片、圖表。

3.C# Excel

這個(gè)是必殺技,100%成功率和兼容性,先安裝nuget依賴(lài),Install-Package Microsoft.Office.Interop.Excel

void ConvertWorkbook()
{
    var app = new Microsoft.Office.Interop.Excel.Application {Visible = false};
    var book = app.Workbooks.Open(@"./test.xls");
    //注意,新的文件名沒(méi)后綴
    book.SaveAs(Filename: @"./test", FileFormat: Microsoft.Office.Interop.Excel.XlFileFormat.xlOpenXMLWorkbook);
    book.Close();
    app.Quit();
}

優(yōu)點(diǎn)
各種格式、類(lèi)型都兼容
缺點(diǎn)
需要在電腦上安裝Excel,運(yùn)行起來(lái)速度有點(diǎn)慢

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,563評(píng)論 19 139
  • Awesome DotNet,這又是一個(gè) Awesome XXX 系列的資源整理,由 quozd 發(fā)起和維護(hù)。內(nèi)容...
    小明yz閱讀 4,023評(píng)論 0 47
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 47,273評(píng)論 6 342
  • 又是一天過(guò)去了。沒(méi)什么特別的事情發(fā)生,這學(xué)期的課程就要結(jié)束了。然后就是暑假工作,再開(kāi)學(xué)。晚上室友說(shuō)圖書(shū)館要搬遷,得...
    青五閱讀 403評(píng)論 0 0
  • 學(xué)院:電子工程學(xué)院 學(xué)號(hào):14020199025 姓名:徐銘晟 計(jì)算機(jī)視覺(jué)是最近炒得火熱的一個(gè)課題。特別是作為最新...
    supportingvecto閱讀 965評(píng)論 4 1

友情鏈接更多精彩內(nèi)容