C#獲取Excel文件所有文本數(shù)據(jù)內(nèi)容的示例代碼
功能需求
獲取上傳的 EXCEL 文件的所有文本信息并存儲(chǔ)到數(shù)據(jù)庫里,可以進(jìn)一步實(shí)現(xiàn)對(duì)文件內(nèi)容資料關(guān)鍵字查詢的全文檢索。有助于我們定位相關(guān)文檔,基本實(shí)現(xiàn)的步驟如下:
1、上傳 EXCEL 文件,獲取二進(jìn)制數(shù)據(jù)并創(chuàng)建副本文件。
2、將EXCEL 副本文件通過 COM API 導(dǎo)出到指定的文本文件。
3、獲取文本文件的內(nèi)容字符串并存儲(chǔ)到數(shù)據(jù)庫中。
范例運(yùn)行環(huán)境
操作系統(tǒng): Windows Server 2019 DataCenter
操作系統(tǒng)上安裝 Office Excel 2016
數(shù)據(jù)庫:Microsoft SQL Server 2016
.net版本: .netFramework4.7.1 或以上
開發(fā)工具:VS2019 C#
關(guān)鍵代碼
組件庫引入

獲取Excel文件的文本內(nèi)容
getExcelContent 方法返回 string 類型內(nèi)容,即表示EXCEL 文件的文本內(nèi)容,說明如下表:
| 序號(hào) | 參數(shù)名 | 類型 | 說明 |
|---|---|---|---|
| 1 | _filename | string | 文件名為全路徑文件信息,方法會(huì)根據(jù)文件路徑創(chuàng)建_path+System.Guid.NewGuid()+".txt" 的臨時(shí)目標(biāo)文件路徑,導(dǎo)入EXCEL文件到 Excel Application ,使用 SAVEAS COM API 導(dǎo)出目標(biāo)文本文件,再獲文本文件內(nèi)容,刪除目標(biāo)文本臨時(shí)文件,將文件內(nèi)容字符串返回。 |
實(shí)現(xiàn)代碼如下:
public string getExcelContent(string _filename)
{
Object Nothing=System.Reflection.Missing.Value;
string _txtfile="",_path=Path.GetDirectoryName(_filename)+"\\",_ext="";
if(!Directory.Exists(_path))
{
Directory.CreateDirectory(_path);
}
_txtfile=_path+System.Guid.NewGuid()+".txt";
object filename=_filename;
//創(chuàng)建一個(gè)名為ExcelApp的組件對(duì)象
DateTime beforetime=DateTime.Now;
Excel.Application excel=new Excel.Application();
excel.DisplayAlerts=false;
excel.AskToUpdateLinks=false;
excel.Visible=true;
DateTime aftertime=DateTime.Now;
Excel.Workbook xb=excel.Workbooks.Add(filename);
Worksheet worksheet = (Worksheet) excel.ActiveSheet;
sheetCount=excel.Sheets.Count;
worksheet.Activate();
worksheet.SaveAs(@_txtfile,XlFileFormat.xlUnicodeText, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
FileEx fe=new FileEx();
excel.Workbooks.Close();
string rv=fe.LoadFromFile(@_txtfile,Encoding.Unicode);
File.Delete(@_txtfile);
excel.Quit();
if(worksheet != null)
{
System.Runtime.InteropServices.Marshal.ReleaseComObject(worksheet);
worksheet = null;
}
if(xb != null)
{
System.Runtime.InteropServices.Marshal.ReleaseComObject(xb);
xb = null;
}
if(excel != null)
{
System.Runtime.InteropServices.Marshal.ReleaseComObject(excel);
excel = null;
}
GC.Collect();
KillProcessByStartTime("EXCEL",beforetime,aftertime);
return rv;
}
public string KillProcessByStartTime(string processName,DateTime beforetime,DateTime aftertime)
{
Process[] ps = Process.GetProcesses();
foreach (Process p in ps)
{
if(p.ProcessName.ToUpper()!=processName) continue;
if(p.StartTime > beforetime && p.StartTime < aftertime)
{
try
{
p.Kill();
}
catch(Exception e)
{
return e.Message;
}
}
}
return "";
}其中 KillProcessByStartTime 用于關(guān)閉未釋放的EXCEL應(yīng)用進(jìn)程。
總結(jié)
以上代碼我們提供了一些操作 EXCEL 的API關(guān)鍵方法,后續(xù)我們可以將文本內(nèi)容存儲(chǔ)到數(shù)據(jù)庫中,查詢或下載,可以參考我的文章:
《C# 將 Word 轉(zhuǎn)文本存儲(chǔ)到數(shù)據(jù)庫并進(jìn)行管理》
關(guān)于 EXCEL 文件導(dǎo)出方法可參考如下官方文檔:
Worksheet.SaveAs 方法 (Excel) | Microsoft Learn
到此這篇關(guān)于C#獲取Excel文件所有文本數(shù)據(jù)內(nèi)容的示例代碼的文章就介紹到這了,更多相關(guān)C#獲取Excel數(shù)據(jù)內(nèi)容內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在winform下實(shí)現(xiàn)左右布局多窗口界面的方法
在web頁面上我們可以通過frameset,iframe嵌套框架很容易實(shí)現(xiàn)各種導(dǎo)航+內(nèi)容的布局界面,而在winform、WPF中實(shí)現(xiàn)其實(shí)也很容易,通過本文給大家介紹在winform下實(shí)現(xiàn)左右布局多窗口界面的方法,本文介紹的非常詳細(xì),對(duì)winform布局相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-02-02
C#編程實(shí)現(xiàn)統(tǒng)計(jì)文件夾內(nèi)文件和隱藏文件的方法示例
這篇文章主要介紹了C#編程實(shí)現(xiàn)統(tǒng)計(jì)文件夾內(nèi)文件和隱藏文件的方法,結(jié)合具體實(shí)例形式分析了C#針對(duì)文件與目錄的遍歷及屬性操作相關(guān)技巧,需要的朋友可以參考下2017-07-07
WPF實(shí)現(xiàn)動(dòng)畫效果(六)之路徑動(dòng)畫
這篇文章介紹了WPF實(shí)現(xiàn)動(dòng)畫效果之路徑動(dòng)畫,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
C#多線程處理多個(gè)隊(duì)列數(shù)據(jù)的方法
本文將結(jié)合實(shí)例代碼,介紹C#多線程處理多個(gè)隊(duì)列數(shù)據(jù)的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06
C#中ManualResetEvent實(shí)現(xiàn)線程的暫停與恢復(fù)
本文主要介紹了C#中ManualResetEvent實(shí)現(xiàn)線程的暫停與恢復(fù),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
C#?EF?Core可視化工具的使用及EF?Core入門語句操作代碼
EF?Core?可用作對(duì)象關(guān)系映射程序?(O/RM),以便于?.NET?開發(fā)人員能夠使用?.NET?對(duì)象來處理數(shù)據(jù)庫,這樣就不必經(jīng)常編寫大部分?jǐn)?shù)據(jù)訪問代碼了,接下來通過本文給大家介紹C#?EF?Core可視化工具的使用及EF?Core入門語句,感興趣的朋友一起看看吧2022-02-02

