.net NPOI C#處理Excel的類庫使用

----------------------------------------------------------
- .net NPOI C#處理Excel的類庫使用
https://www.nuget.org/packages/NPOI/
VS->工具->程序包管理器控制檯 運行 PM> Install-Package NPOI -Version 2.3.0
相關DLL引用自動添加到項目中,命名空間中添加以下聲明:
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;工具

-------------------------------------------------------
- 用nuget下載舊版本的軟件包
SharpZipLib 必須用0.86版本的,不然NPOI打開EXCEL時會出錯。
若是更新了SharpZipLib到1.0.0版本,必須roll back到0.86.0版,或者卸載從新安裝NPOI。this

在Visual Studio中打開包管理器控制檯 – 它在工具/ NuGet包管理器/包管理器控制檯中。而後運行Install-Package命令:
Install-Package ICSharpCode.SharpZipLib -Version 0.86.0.518 或者0.86.0.net

編輯:
爲了列出包的版本,您能夠使用帶有遠程參數和過濾器的Get-Package命令:ip

Get-Package -ListAvailable -Filter Common.Logging -AllVersions
經過在Install-Package命令中的版本選項後按Tab鍵,能夠得到最新可用版本的列表。get

I also met this problem with VS2017, NPOI 2.3.0 and SharpZipLib 1.0.0.
I didn't solve the problem changing the verison of the SharpZipLib to 0.86 in NuGet. After test, I found that it should also delete the below content in the App.config if it has that:string

<assemblyIdentity name="ICSharpCode.SharpZipLib" publicKeyToken="1b03e6acf1164f73" culture="neutral"/>
<bindingRedirect oldVersion="0.0.0.0-1.0.0.999" newVersion="1.0.0.999"/>
So that, not only roll back the verison of the SharpZipLib to 0.86, but also modify the App.config.it

------------------------------------------------------------
Excel 用NPOI編輯寫入後打不開,嘗試如下解決:
FileMode.Open is working with .xls files but not .xlsx files.
using (var file = new FileStream(fileName, FileMode.Create, FileAccess.Write))
{
workbook.Write(file);
}io

I think the problem is that you are reading from, and writing to, the same FileStream. You should be doing the read and write using separate streams. Try it like this:test

string newPath = @"C:\MyPath\test.xlsx";stream

// read the workbook
IWorkbook wb;
using (FileStream fs = new FileStream(newPath, FileMode.Open, FileAccess.Read))
{
wb = new XSSFWorkbook(fs);
}

// make changes
ISheet s = wb.GetSheetAt(0);
IRow r = s.GetRow(0) ?? s.CreateRow(0);
ICell c = r.GetCell(1) ?? r.CreateCell(1);
c.SetCellValue("test2");

// overwrite the workbook using a new streamusing (FileStream fs = new FileStream(newPath, FileMode.Create, FileAccess.Write)){ wb.Write(fs);}

相關文章
相關標籤/搜索