午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

使用C#如何導(dǎo)入導(dǎo)出Excel文件?

瀏覽:297日期:2022-10-15 08:19:47

問題描述

使用C#如何導(dǎo)入導(dǎo)出Excel文件?

問題解答

回答1:

使用C#如何導(dǎo)入導(dǎo)出Excel文件?-PHP中文網(wǎng)問答-使用C#如何導(dǎo)入導(dǎo)出Excel文件?-PHP中文網(wǎng)問答

圍觀一下哦,學(xué)習(xí)一下。

回答2:

OleDB是微軟的戰(zhàn)略性的通向不同的數(shù)據(jù)源的低級(jí)應(yīng)用程序接口。支持很多種數(shù)據(jù)庫,此客戶端中DBF文件的輸入輸出也是使用了此數(shù)據(jù)庫API。使用OleDB記得添加上命名空間:

using System.Data.OleDb;

xlsx文件的輸入:

private void inputXlsx(){ string strConn2; string filePath = inPath; FileInfo fileInfo = new FileInfo(filePath); string directory = fileInfo.DirectoryName; strConn2 = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source='{0}'; Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;';"; string strConnection = string.Format(strConn2, inPath); OleDbConnection conn = new OleDbConnection(strConnection); try {conn.Open();String tableName = null;DataTable dt = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);tableName = dt.Rows[0][2].ToString().Trim();OleDbDataAdapter oada = new OleDbDataAdapter("select * from [" + tableName + "]", strConnection);oada.Fill(dtOld);conn.Close(); } catch (Exception ex) {conn.Close(); }}

xlsx文件的中間處理過程因需求而異,在此不再贅述處理方式。在輸入過程中,將文件中的數(shù)據(jù)轉(zhuǎn)化成了Datatable數(shù)據(jù)類型的格式,它是一個(gè)臨時(shí)保存數(shù)據(jù)的網(wǎng)格虛擬表,處理非常方便。

xlsx文件的輸出:xlsx文件的輸出過程并不是很順利,先后使用了三種方式。

第一種方式自然就是OleDB了,有始有終嘛。但是真正使用的過程中發(fā)現(xiàn)此方式不僅要求程序運(yùn)行本機(jī)必須安裝Excel,而且對(duì)Excel版本要求非常高,如果刪注冊(cè)表很容易弄巧成拙,我改注冊(cè)表就直接玩壞了Excel。事實(shí)上我們并不能保證客戶的機(jī)器上一定安裝了對(duì)應(yīng)版本的Excel,所以如果使用OleDB輸出文件,此客戶端的兼容性將非常的低劣。

經(jīng)過一番溝通和掙扎決定還是換一種方式,決定改用第三方組件。由于JAVA方使用的是POI,所以這邊直接使用POI項(xiàng)目的.NET版本,NPOI。網(wǎng)上教程很多,很好實(shí)現(xiàn),但是經(jīng)過測(cè)試之后,此種方式對(duì)大文件的輸入輸出支持的不是很好,處理DEMO文件沒有問題,但是換成了真正客戶提供的十萬行級(jí)甚至百萬行級(jí)的文件,客戶端直接在輸出的過程中崩掉。

查詢資料后,網(wǎng)友們對(duì)于大文件都建議使用EPPlus。教程也是一抓一大把,我沒有繼續(xù)加大文件大小測(cè)試,不過客戶給我們提供的十來個(gè)文件全部測(cè)試通過,基本上都是百萬級(jí)以下的。

上代碼吧:

private void outputXlsx(){ FileInfo newFile = new FileInfo(dtNew.TableName + ".xlsx"); if (newFile.Exists) {newFile.Delete();newFile = new FileInfo(dtNew.TableName + ".xlsx"); } using (ExcelPackage package = new ExcelPackage(newFile)) {ExcelWorksheet worksheet = package.Workbook.Worksheets.Add(dtNew.TableName);//創(chuàng)建worksheet for (int m = 0; m < dtNew.Columns.Count; m++){ worksheet.Cells[1, m + 1].Value = dtNew.Columns[m];}int i = 1;foreach (DataRow dr in dtNew.Rows){ for (int j = 0; j < dtNew.Columns.Count; j++) {worksheet.Cells[i + 1, j + 1].Value = dr[j]; } i++;}package.Save();//保存excel }}

標(biāo)簽: excel
相關(guān)文章:
主站蜘蛛池模板: 丁香花五月婷婷 | 黄色免费影片 | 精品久久一区 | 一区二区三区中文字幕 | av大片免费看 | 久久国产99 | 国产极品少妇 | 欧美精品久久久久久久久老牛影院 | 久草视频在线免费播放 | av亚洲精品 | 一级色视频 | 91原创国产 | 欧美精品亚洲精品 | www.黄色片 | 国产精品自拍视频 | 国产精品一级 | 久久激情网 | 午夜在线小视频 | 国产一区久久久 | 国产精品第56页 | 成人看片黄a免费看视频 | 黄色福利在线观看 | 在线免费观看中文字幕 | 亚洲视频在线观看一区二区 | 日本黄大片| 精品国产区一区二 | 欧美疯狂做受xxxxx高潮 | 日韩免费视频一区二区视频在线观看 | 亚洲精品偷拍视频 | 天天色婷婷 | 日韩欧美自拍偷拍 | 成人99视频 | 国产老头老太做爰视频 | 精品亚洲在线 | 天天操免费视频 | 成年人看的免费视频 | 亚洲一二三四在线 | 国产jizz18女人高潮 | 国产黄色一区 | 欧美日韩一级在线观看 | 国产成人在线视频播放 |