C#操作Excel文件(转)
關(guān)鍵詞:受管代碼;非受管代碼;Excel對(duì)象;動(dòng)態(tài)連接庫(kù)
引言
Excel是微軟公司辦公自動(dòng)化套件中的一個(gè)軟件,他主要是用來(lái)處理電子表格。 Excel以其功能強(qiáng)大,界面友好等受到了許多用戶(hù)的歡迎。在設(shè)計(jì)應(yīng)用系統(tǒng)時(shí),對(duì)于不同的用戶(hù),他們對(duì)于打印的需求是不一樣的,如果要使得程序中的打印功 能適用于每一個(gè)用戶(hù),可以想象程序設(shè)計(jì)是十分復(fù)雜的。由于Excel表格的功能強(qiáng)大,又由于幾乎每一臺(tái)機(jī)器都安裝了它,如果把程序處理的結(jié)果放到 Excel表格中,這樣每一個(gè)用戶(hù)就可以根據(jù)自己的需要在Excel中定制自己的打印。這樣不僅使得程序設(shè)計(jì)簡(jiǎn)單,而且又滿(mǎn)足了諸多用戶(hù)的要求,更加實(shí)用 了。那么用Visual C#如何調(diào)用Excel,如何又把數(shù)據(jù)存放到Excel表格中?本文就來(lái)探討上述問(wèn)題的解決辦法。
Excel對(duì)象
微軟的Excel對(duì)象模型包括了128個(gè)不同的對(duì)象,從矩形,文本框等簡(jiǎn)單的對(duì)象到透視表,圖表等復(fù)雜的對(duì)象.下面我們簡(jiǎn)單介紹一下其中最重要,也是用得最多的四個(gè)對(duì)象。
(1) Application對(duì)象。Application對(duì)象處于Excel對(duì)象層次結(jié)構(gòu)的頂層,表示Excel自身的運(yùn)行環(huán)境。
(2) Workbook對(duì)象。Workbook對(duì)象直接地處于Application對(duì)象的下層,表示一個(gè)Excel工作薄文件。
(3) Worksheet對(duì)象。Worksheet對(duì)象包含于Workbook對(duì)象,表示一個(gè)Excel工作表。
(4) Range對(duì)象。Range對(duì)象包含于Worksheet對(duì)象,表示Excel工作表中的一個(gè)或多個(gè)單元格。
C#中的受管代碼和非受管代碼
在.net公用語(yǔ)言框架內(nèi)運(yùn)行的程序?yàn)槭芄艽a。受管代碼在程序中所有類(lèi)型都受到嚴(yán)格檢 查,沒(méi)有指針,對(duì)內(nèi)存的管理完全由運(yùn)行系統(tǒng)控制。受控狀態(tài)下,編寫(xiě)程序更為容易,且更少出錯(cuò),我們可以花更多的時(shí)間在解決實(shí)際問(wèn)題上而不是在計(jì)算機(jī)語(yǔ)言問(wèn) 題上。相對(duì)而言,那些在.NET框架外運(yùn)行的程序?yàn)榉鞘芄艽a。比如:COM組件、ActiveX組件、Win32 API函數(shù)、指針運(yùn)算等。C#編程中在某些特定情況下,需要運(yùn)用非受管代碼,例如,要利用一個(gè)成熟的COM組件,或者調(diào)用一個(gè)API函數(shù),或者用指針去編 寫(xiě)實(shí)時(shí)/高效程序等。
Visual C#中調(diào)用Excel的COM組件
一個(gè).NET組件事實(shí)上是一個(gè).NET下的DLL,它包含的不僅是運(yùn)行程序本身,更重要的是包含這個(gè)DLL的描述信息(Meta Data,即元數(shù)據(jù)),而一個(gè)COM組件是用其類(lèi)庫(kù)(TLB)儲(chǔ)存其描述信息。這些COM組件都是非受管代碼,要在Visual C#中使用這些非受管代碼的COM組件,就必須把他們轉(zhuǎn)換成受管代碼的.NET組件。所以在用Visual C#調(diào)用Excel表格之前,必須完成從COM組件的非受管代碼到受管代碼的類(lèi)庫(kù)的轉(zhuǎn)換。
1、將Excel的COM組件轉(zhuǎn)換為.NET組件
在項(xiàng)目中打開(kāi)Add Reference對(duì)話框,選擇COM欄,之后在COM列表中找到"Microsoft Excel 9.0 Object Library"(Office 2000),然后將其加入到項(xiàng)目的References中即可。Visual C#.NET會(huì)自動(dòng)產(chǎn)生相應(yīng)的.NET組件文件,以后即可正常使用。
這個(gè)轉(zhuǎn)換形成.NET組件不能單獨(dú)使用,它不過(guò)是以前的COM組件的一個(gè)外層包裝,在.NET中可以通過(guò)這個(gè)外層包裝去發(fā)現(xiàn)原來(lái)的COM組件并調(diào)用其相應(yīng)的界面函數(shù)。所以它必須與原來(lái)的COM組件一起起作用。
2、Visual C#打開(kāi)Excel表格
事實(shí)上,在C#中使用一個(gè)經(jīng)轉(zhuǎn)換的COM組件和使用任何一個(gè)其它.NET組件完全一樣。可以用new關(guān)鍵字創(chuàng)建一個(gè)經(jīng)轉(zhuǎn)換的COM組件,然后再像使用任何一個(gè)其它C#對(duì)象一樣使用這個(gè)組件對(duì)象。
在轉(zhuǎn)換后的.NET組件中定義了一個(gè)命名空間Excel,在此命名空間中封裝了一個(gè)類(lèi)Application,這個(gè)類(lèi)和啟動(dòng)Excel表格有非常重要的關(guān)系,在Visual C#中,只需要下列三行代碼就可以完成打開(kāi)Excel表格的工作,具體如下:
| Excel.Application excel = new Excel.Application ();//引用Excel對(duì)象 excel.Application.Workbooks.Add ( true );//引用Excel工作簿 excel.Visible = true ;//使Excel可視 |
但此時(shí)的Excel表格是一個(gè)空的表格,沒(méi)有任何內(nèi)容,下面就來(lái)介紹如何往Excel表格中輸入數(shù)據(jù)。
3、往Excel表格中輸入數(shù)據(jù)
在命名空間"Excel"中,還定義了一個(gè)類(lèi)"Cell",這個(gè)類(lèi)所代表的就是Excel表格中的一個(gè)單元格。通過(guò)給"Cell"賦值,從而實(shí)現(xiàn)往Excel表格中輸入相應(yīng)的數(shù)據(jù),下列代碼功能是打開(kāi)Excel表格,并且往表格輸入一些數(shù)據(jù)。
| Excel.Application excel = new Excel.Application () ; excel.Application.Workbooks.Add ( true ) ; excel.Cells[ 1 , 1 ] = "First Row First Column" ; excel.Cells[ 1 , 2 ] = "First Row Second Column" ; excel.Cells[ 2 , 1 ] = "Second Row First Column" ; excel.Cells[ 2 , 2 ] = "Second Row Second Column" ; excel.Visible = true ; |
?
4、實(shí)例
下面實(shí)例在C#中連接Oracle數(shù)據(jù)庫(kù)(Name),從表(TableName)中讀取數(shù)據(jù),并寫(xiě)入Excel。
| string cnString="Provider=msdaora.1;Data source=Name; "; cnString=cnString+"user id=UserName;password=Password"; try { OleDbConnection cn=new OleDbConnection (cnString); cn.Open (); try { string s="select * from Name.TableName"; OleDbCommand cmd=new OleDbCommand (s,cn); OleDbDataReader dr=cmd.ExecuteReader (); Excel.Application xlApp = new Excel.Application(); if(xlApp==null){MessageBox.Show ("Can't open Excel!");return;} xlApp.Application .Workbooks .Add (true); int row=2,fieldcount; fieldcount=dr.FieldCount ; for(int col=0;col<fieldcount;col++) xlApp.Cells [1,col+1]=dr.GetName(col); while (dr.Read ()) { for(int col=0;col<fieldcount;col++) xlApp.Cells [row,col+1]=dr.GetValue(col).ToString(); row++; } xlApp.Visible =true; xlApp=null; } catch(Exception ex ){MessageBox.Show (ex.Message );} finally {cn.Close();} } catch(Exception ex){MessageBox.Show (ex.Message );} } } |
5、安裝一個(gè)使用COM組件的.net程序
如果要將這樣的程序安裝運(yùn)行在另一臺(tái)機(jī)器上,那么除了安裝運(yùn)行程序外,還做三件事。
首先,是安裝.NET運(yùn)行系統(tǒng)。因?yàn)槿魏我粋€(gè).NET程序都不能離開(kāi).NET運(yùn)行系統(tǒng)去獨(dú)立運(yùn)行。
其次,所調(diào)用的COM組件必須要安裝在目標(biāo)機(jī)器上。本例中大多數(shù)目標(biāo)機(jī)器上都裝有Microsoft Office的Excel,一般不會(huì)有這個(gè)問(wèn)題。但如果是另一個(gè)用戶(hù)自定義的COM組件,那么這個(gè)COM組件在運(yùn)行.NET程序之前必須先安裝好。
最后,轉(zhuǎn)換后的.NET組件DLL文件要安裝在目標(biāo)機(jī)器上。因?yàn)?NET組件不需要在Windows ReGIStry中注冊(cè),所以最簡(jiǎn)單的方法是將.NET組件DLL文件拷貝到運(yùn)行程序目錄下。如果此.NET組件被多個(gè).NET程序共享,可以將其安裝在.NET公用組件區(qū)中,從而可被任何一個(gè).NET組件使用。只有當(dāng)一個(gè).NET組件參與了事務(wù)處理時(shí),才需要將它注冊(cè)為一個(gè)COM+組件。因?yàn)?NET仍然用傳統(tǒng)的COM+機(jī)制來(lái)處理事務(wù)的提交、回滾等。
小結(jié)
通過(guò)以上討論,我們知道了在C#中,如何使用Excel的COM組件。需要注意的是,Excel對(duì)象包含的許多內(nèi)容我們沒(méi)有介紹,在使用過(guò)程中需要我們不斷學(xué)習(xí)。也使我們了解了在C#中如何使用COM組件。
參考文獻(xiàn):
[1] 劉洪成 C#高級(jí)編程 清華大學(xué)出版社 2003.7工作 187~200
====================================================================================
| ||||||
| ? | 前些日子,有很多朋友說(shuō)需要C#導(dǎo)出到Excel的代碼,現(xiàn)共享給大家 /// <summary> /// <summary> 這種方法目前最有效,如果有不明白的地方可以來(lái)信交流 ? 作者Blog:http://blog.csdn.net/lovelyxc/ |
====================================================================================
首先將excel.exe copy 到 ..\Microsoft Visual Studio .NET 2003\SDK\v1.1\Bin目錄下
利用.net 中帶的工具在命令提示符下執(zhí)行tlbimp excel.exe.這樣就不會(huì)因?yàn)槟愕腅xcel是xp或2000的不同要去找不同的*.olb文件,還有一點(diǎn)就是因?yàn)樵?000以后的版本中沒(méi)有了excel9.olb這個(gè)文件了。
通過(guò)執(zhí)行tlbimp excel.exe后我們會(huì)得到excel.dll文件。
只要有了這個(gè)Excel.dll,現(xiàn)在我們就能使用Excel的各種操作函數(shù)了。
下面就讓我們具體看看C#是如何使用這些東東吧。
1. 創(chuàng)建一個(gè)新Excel的Application:
Application exc = new Application();
if (exc == null) {
Console.WriteLine("ERROR: EXCEL couldn't be started");
return 0;
}
2. 讓這個(gè)工程可見(jiàn):
exc.set_Visible(0, true);
3. 獲取WorkBooks集合:
Workbooks workbooks = exc.Workbooks;
4. 加入新的WorkBook:
_Workbook workbook = workbooks.Add(XlWBATemplate.xlWBATWorksheet, 0);
5. 獲取WorkSheets集合:
_Worksheet worksheet = (_Worksheet) sheets.get_Item(1);
if (worksheet == null) {
Console.WriteLine ("ERROR in worksheet == null");
}
6. 給單元格設(shè)置變量:
?
Range?range1?=?worksheet.get_Range("C1",Missing.Value);if?(range1?==?null)?
{
Console.WriteLine?("ERROR:?range?==?null");
}
const?int?nCells?=?1;
Object[]?args1?=?new?Object[1];
args1[0]?=?nCells;
range1.GetType().InvokeMember("Value",BindingFlags.SetProperty,?null,?range1,?args1);
?
例程:
?
using?System;using?System.Reflection;?
using?System.Runtime.InteropServices;?
using?Excel;
class?Excel?{
public?static?int?Main()?{
Application?exc?=?new?Application();
if?(exc?==?null)?{
Console.WriteLine("ERROR:?EXCEL?couldn't?be?started!");
return?0;
}
exc.set_Visible(0,?true);?
Workbooks?workbooks?=?exc.Workbooks;
_Workbook?workbook?=?workbooks.Add(XlWBATemplate.xlWBATWorksheet,?0);?
Sheets?sheets?=?workbook.Worksheets;
_Worksheet?worksheet?=?(_Worksheet)?sheets.get_Item(1);
if?(worksheet?==?null)?{
Console.WriteLine?("ERROR:?worksheet?==?null");
}
Range?range1?=?worksheet.get_Range("C1",?Missing.Value);
if?(range1?==?null)?{
Console.WriteLine?("ERROR:?range?==?null");
}
const?int?nCells?=?1;
Object[]?args1?=?new?Object[1];
args1[0]?=?nCells;
range1.GetType().InvokeMember("Value",?BindingFlags.SetProperty,?null,range1,?args1);
return?100;
}
}
現(xiàn)在我們來(lái)看看如何使用數(shù)組,他有些類(lèi)似于設(shè)置單元格。僅僅需要的改變只是args2[0] = array2;
Range?range2?=?worksheet.get_Range("A1",?"E1");
int[]?array2?=?new?int?[nCell];
for?(int?i=0;?i?<?array2.GetLength(0);?i++)?
{
array2[i]?=?i+1;
}
Object[]?args2?=?new?Object[1];
args2[0]?=?array2;
range2.GetType().InvokeMember("Value",?BindingFlags.SetProperty,?null,?range2,?args2);
大家需要了解Tlbimp這個(gè)工具的使用啊:)這個(gè)東東很有用,可以將普通Win32程序移植到.Net下面來(lái):)
如果操作的excel的格式很簡(jiǎn)單,就是一般的表的結(jié)構(gòu),那么其實(shí)操作EXCEL文件跟操作ACCESS數(shù)據(jù)庫(kù)文件的方法幾乎一樣。
(需要注意的地方就是,1、程序會(huì)把EXCLE表中的第一行記錄作為列名;2、在使用EXCLE表的時(shí)候, 要在表名后面加上符號(hào)$)
下面,我給你帖一段如何連接和讀取EXCEL文件的代碼吧:
?
OleDbDataAdapter?ad;
string?strDbPath?=?"./code.xls";
string?strConn?=?"Provider=Microsoft.Jet.OleDb.4.0;?Data?Source="+Server.MapPath(strDbPath)+";?Extended?Properties=Excel?8.0;";
OleDbConnection?Conn?=?new?OleDbConnection(strConn);
Conn.Open();
string?strSQL?=?"select?*?from?[股票代碼$]";
ad?=?new?OleDbDataAdapter(strSQL,?Conn);
ad.Fill(ds);
dg1.DataSource?=?ds.Tables[0].DefaultView;??//dg1是一個(gè)DataGrid控件
dg1.DataBind();??//將EXCLE中股票代碼中的記錄棒定到DataGrid控件上
如果是在asp.net 下使用的話,要記得在? <system.web>中添加<identity impersonate="true"/>
否則就會(huì)出現(xiàn) “異常詳細(xì)信息: System.UnauthorizedAccessException: 拒絕訪問(wèn)“。
=======================================================
一、調(diào)用Excel的方法:一般情況下有兩種方法調(diào)用Excel:
1、 ?直接使用Delphi自帶的組件:在Form中分別放入ExcelApplication, ExcelWorkbook和ExcelWorksheet。
2、動(dòng)態(tài)創(chuàng)建Excel文件:首先創(chuàng)建 Excel 對(duì)象,使用ComObj,Excel2000:
var ExcelApp: Variant;
ExcelApp := CreateOleObject( 'Excel.Application' );
二、導(dǎo)入數(shù)據(jù):在程序中,我們可以將查詢(xún)到的數(shù)據(jù)(SQL、Access、)導(dǎo)入到Excel中。例如:用Adoquery查詢(xún)Access中的數(shù)據(jù):
1、先查到所需的數(shù)據(jù);
2、導(dǎo)入:i:=1;
Adoquery.First;
? ? ? ? ? ? ? while not Adoquery.Eof do
? ? ? ? ? ? ? ? Begin
? ? ? ? ? ? ? ? ? ExcelApp.WorkSheets[1].Cells[i,1].Value := i;//添加序號(hào)的值
ExcelApp.WorkSheets[1].Cells[i,2].Value := Adoquery.FieldByName('cp_name').AsString;
? ? ? ? ? ? ? ? ? ……
? ? ? ? ? ? ? ? ? Inc(i);
Adoquery.Next;
? ? ? ? ? ? ? ? End;
當(dāng)然也可以把Adotable、Adoquery、Table、Query等組件的數(shù)據(jù)導(dǎo)入到Excel中。
三、Excel的處理:如果在你已知Excel格式的情況下,可以控制Excel,如下:
1、 顯示當(dāng)前窗口:ExcelApp.Visible := True;
2、 更改 Excel 標(biāo)題欄:ExcelApp.Caption := '標(biāo)題內(nèi)容';
3、 添加新工作簿:ExcelApp.WorkBooks.Add;
4、 設(shè)置第2個(gè)工作表為活動(dòng)工作表:ExcelApp.WorkSheets[2].Activate;
5、 給單元格賦值:ExcelApp.Cells[1,1].Value := '第一行第一列';
6、 設(shè)置指定列的寬度(單位:字符個(gè)數(shù)),以第一列為例:
ExcelApp.ActiveSheet.Columns[1].ColumnsWidth := 5;
7、 設(shè)置指定行的高度(單位:磅)(1磅=0.035厘米),以第二行為例:
ExcelApp.ActiveSheet.Rows[2].RowHeight := 1/0.035; // 1厘米
8、文字水平居中:Excelid.worksheets[1].Rows[1].HorizontalAlignment := $FFFFEFF4;
? 文字垂直居中:Excelid.worksheets[1].Rows[1].VerticalAlignment := $FFFFEFF4;
9、 插入一行或一列:a. ExcelApp.ActiveSheet.Rows[2].Insert;
b. ExcelApp.ActiveSheet.Columns[1].Insert;
10、 刪除一行或一列:a. ExcelApp.ActiveSheet.Rows[2].Delete;
b. ExcelApp.ActiveSheet.Columns[1].Delete; ?
11、合并單元格:ExcelApp.worksheets[1].range[A1:F8'].Merge(abc);注:要聲明變量abc: Variant;
12、豎行顯示文字:ExcelApp.worksheets[1].Cells.Item[1,1].Orientation:= xlVertical;
13、單元格加邊線:ExcelApp.worksheets[1].Range[A1:F8].Borders.LineStyle := 1;
14、在第8行之前插入分頁(yè)符:ExcelApp.WorkSheets[1].Rows[8].PageBreak := 1;
15、在第4列之前刪除分頁(yè)符:ExcelApp.ActiveSheet.Columns[4].PageBreak := 0;
16、指定邊框線寬度:ExcelApp.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3;
1-左 ? ?2-右 ? 3-頂 ? ?4-底 ? 5-斜( \ ) ? ? 6-斜( / )
17、拷貝操作:a.拷貝整個(gè)工作表:ExcelApplication1.ActiveSheet.Used.Range.Copy;
b.拷貝指定區(qū)域:ExcelApplication1.ActiveSheet.Range[ 'A1:E2' ].Copy;
? ? ? ? ? ? ? ? ?c.從A1位置開(kāi)始粘貼:ExcelApplication1.ActiveSheet.Range.[ 'A1' ].PasteSpecial;
d.從文件尾部開(kāi)始粘貼:ExcelApplication1.ActiveSheet.Range.PasteSpecial;
18、清除第一行第四列單元格公式:ExcelApp.ActiveSheet.Cells[1,4].ClearContents;
19、工作表保存:if not ExcelApp.ActiveWorkBook.Saved then
? ? ? ? ? ? ? ?ExcelApp.ActiveSheet.PrintPreview;
20、工作表另存為:ExcelApp.SaveAs( 'C:\Excel\Demo1.xls' );
21、放棄存盤(pán):ExcelApp.ActiveWorkBook.Saved := True;
22、關(guān)閉工作簿:ExcelApp.WorkBooks.Close;
23、退出 Excel:ExcelApp.Quit;
下面是有關(guān)打印頁(yè)面控制的語(yǔ)句:
? ?24、設(shè)置第一行字體屬性:ExcelApp.ActiveSheet.Rows[1].Font.Name := '隸書(shū)';
ExcelApp.ActiveSheet.Rows[1].Font.Color := clBlue;
ExcelApp.ActiveSheet.Rows[1].Font.Bold := True;
ExcelApp.ActiveSheet.Rows[1].Font.UnderLine := True;
ExcelApp.ActiveSheet.Rows[1].Font.size:=10;
25、進(jìn)行頁(yè)面設(shè)置:a.頁(yè)眉:ExcelApp.ActiveSheet.PageSetup.CenterHeader := '報(bào)表演示';
b.頁(yè)腳:ExcelApp.ActiveSheet.PageSetup.CenterFooter := '共&N頁(yè) 第&P頁(yè)';
? ? ? ? ? ? ? ? ? ? ?c.頁(yè)眉到頂端邊距2cm:ExcelApp.ActiveSheet.PageSetup.HeaderMargin := 2/0.035;
d.頁(yè)腳到底端邊距3cm:ExcelApp.ActiveSheet.PageSetup.HeaderMargin := 3/0.035;
? ? ? ? ? ? ? ? ? ? ?e.頂邊距2cm:ExcelApp.ActiveSheet.PageSetup.TopMargin := 2/0.035;
f.底邊距2cm:ExcelApp.ActiveSheet.PageSetup.BottomMargin := 2/0.035;
? ? ? ? ? ? ? ? ? ? ?g.左邊距2cm:ExcelApp.ActiveSheet.PageSetup.LeftMargin := 2/0.035;
h.右邊距2cm:ExcelApp.ActiveSheet.PageSetup.RightMargin := 2/0.035;
? ? ? ? ? ? ? ? ? ? ?i.頁(yè)面水平居中:ExcelApp.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035;
j.頁(yè)面垂直居中:ExcelApp.ActiveSheet.PageSetup.CenterVertically := 2/0.035;
? ? ? ? ? ? ? ? ? ? ?k.打印單元格網(wǎng)線:ExcelApp.ActiveSheet.PageSetup.PrintGridLines := True;
26、打印預(yù)覽工作表:ExcelApp.ActiveSheet.PrintPreview;
27、打印輸出工作表:ExcelApp.ActiveSheet.PrintOut;
對(duì)Excel的其他控制:
28、excel的多單元格合計(jì)功能:ExcelApp..Cells[ARow, ACol].Formula
:= '= SUM($+IntToStr(BeginRow) +:$ + IntToStr(EndRow) +');
注:聲明變量ARow, ACol: Integer;
29、打開(kāi)已經(jīng)存在的Excel文件: ExcelApplication1.Workbooks.Open (c:\a.xls
EmptyParam,EmptyParam,EmptyParam,EmptyParam,
EmptyParam,EmptyParam,EmptyParam,EmptyParam,
? ?EmptyParam,EmptyParam,EmptyParam,EmptyParam,0);
| ? | 查看評(píng)語(yǔ)???? ? |
?2004-3-4 16:41:04? ? 舉例來(lái)說(shuō)
二、選擇excel表'按鈕,用于打開(kāi)EXCEL文件,其代碼如下:
procedure TForm1.Button1Click(Sender: TObject);
var i,j:integer;
begin
opendialog1.InitialDir:=ExtractFileDir(paramstr(0));//文件的打存放初始路徑
opendialog1.Execute;
Try
ExcelApplication1.Connect;//EXCEL應(yīng)用程序
Except
MessageDlg('Excel may not be installed',mtError, [mbOk], 0);
Abort;
End;
ExcelApplication1.Visible[0]:=True;
ExcelApplication1.Caption:='Excel Application';
try
excelapplication1.Workbooks.Open(opendialog1.FileName,
null,null,null,null,null,null,null,null,null,null,null,null,0);//打開(kāi)指定的EXCEL 文件
except
begin
ExcelApplication1.Disconnect;//出現(xiàn)異常情況時(shí)關(guān)閉
ExcelApplication1.Quit;showmessage('請(qǐng)選擇EXCEL電子表格!');
exit;
end;
end;
ExcelWorkbook1.ConnectTo(ExcelApplication1.Workbooks[1]);//ExcelWorkbook1與Eexcelapplication1建立連接
ExcelWorksheet1.ConnectTo(ExcelWorkbook1.Worksheets[1] as _Worksheet);//Excelworksheet1與Excelworkbook1建立連接
//開(kāi)始從EXCEL中取數(shù),放到stringgrid1中,取完數(shù)后關(guān)閉EXCEL
for i:=1 to 1000 do//最大取值1000
for j:=1 to 6 do
begin
if trim(excelworksheet1.cells.item[i+1,1])<>'' then
begin
stringgrid1.rowCount:=i+1;
stringgrid1.Cells[j,i]:=ExcelWorksheet1.Cells.Item[i+1,j];
end
else
begin
label3.caption:=inttostr(i-1);
ExcelApplication1.Disconnect;
ExcelApplication1.Quit;
//將第一條數(shù)據(jù)賦給編輯框
edit2.text:=stringgrid1.Cells[1,1];
edit1.text:=stringgrid1.Cells[2,1];
edit3.text:=stringgrid1.Cells[3,1];
edit4.text:=stringgrid1.Cells[4,1];
edit5.text:=stringgrid1.Cells[5,1];
exit;
end;
end;
end;
三、'下一條記錄'按鈕,完成記錄向下移動(dòng),代碼如下:
procedure TForm1.Button2Click(Sender: TObject);
var x:integer;
begin
x:=stringgrid1.row+1;
if x<> stringgrid1.RowCount then
begin
stringgrid1.row:=stringgrid1.row+1;
label1.caption:=inttostr(x);
edit2.text:=stringgrid1.Cells[1,x];
edit1.text:=stringgrid1.Cells[2,x];
edit3.text:=stringgrid1.Cells[3,x];
edit4.text:=stringgrid1.Cells[4,x];
edit5.text:=stringgrid1.Cells[5,x];
exit;
end
else
showmessage('已到第一條記錄!');
end;
四、'上一條記錄',完成記錄上移,代碼如下:
var x:integer;
begin
x:=stringgrid1.row-1;
if x<>0 then
begin
stringgrid1.row:=stringgrid1.row-1;
label1.caption:=inttostr(x);
edit2.text:=stringgrid1.Cells[1,x];
edit1.text:=stringgrid1.Cells[2,x];
edit3.text:=stringgrid1.Cells[3,x];
edit4.text:=stringgrid1.Cells[4,x];
edit5.text:=stringgrid1.Cells[5,x];
exit;
end
else
showmessage('已到最后一條記錄!');
end;
五、stringgrid中上下移動(dòng)時(shí)代碼:
procedure TForm1.StringGrid1Click(Sender: TObject);
var i:integer;
begin
i:=stringgrid1.Row;
label1.caption:=inttostr(i);
edit1.text:=stringgrid1.Cells[2,i];
edit2.text:=stringgrid1.Cells[1,i];
edit3.text:=stringgrid1.Cells[3,i];
edit4.text:=stringgrid1.Cells[4,i];
edit5.text:=stringgrid1.Cells[5,i];
end; ?
?2004-3-4 16:45:24? ? 圖片插入到EXCEL中
uses:clipbrd
function
begin
var
?MyFormat:Word;
?AData:THandle; ? ? ?//臨時(shí)句柄變量。
?APalette:HPALETTE; ?//臨時(shí)變量。
?Stream1:TMemoryStream;//TBlobStream
?xx:tbitmap;
? ? ? ? ? ?Stream1:= TMemoryStream.Create;
? ? ? ? ? ?TBlobField(query.FieldByName('存儲(chǔ)圖片的字段')).SaveToStream(Stream1);
? ? ? ? ? ?Stream1.Position :=0;
? ? ? ? ? ?xx:=tbitmap.Create ;
? ? ? ? ? ?xx.LoadFromStream(Stream1);
? ? ? ? ? ?xx.SaveToClipboardFormat(MyFormat,AData,APalette);
? ? ? ? ? ?ClipBoard.SetAsHandle(MyFormat, AData);
? ? ? ? ? ?myworksheet1.Range['g3','h7'].select;//myworksheet1是當(dāng)前活動(dòng)的sheet頁(yè)
? ? ? ? ? ?myworksheet1.Paste;
end;
============================================================
各位兄弟:讀取EXCEL數(shù)據(jù)是有的麻煩,經(jīng)過(guò)研究,已搞掂,C#的代碼如下,至于寫(xiě)數(shù)據(jù)則較簡(jiǎn)單: ?
? Excel.ApplicationClass ? excel=new ? Excel ? .ApplicationClass ? (); ?
? excel.Workbooks ? .Add(path);//打開(kāi)麻煩,增加一個(gè)較好處理 ?
? Excel.Worksheet ? worksheet=(Excel.Worksheetexcel.Worksheets.get_Item ? (1); ?
? for(int ? i=1;i<=row;i++) ?
? { ?
? Excel.Range ? r=worksheet.get_Range ? ("A"+i.ToString ? (),"A"+i.ToString ? ()); ?
? r.Select ? (); ?
? labcellname.Text ? =excel.ActiveCell.Text ? .ToString ? ().Trim ? (); ?
? Application.DoEvents ? (); ?
? labnum.Text ? =i.ToString ? (); ?
? Application.DoEvents ? (); ?
? } ?
? excel.Quit ? ();
?
?
?
?
?
?
C#操作Excel的方法
一. 直接調(diào)用COM組件
(如excel 2003)引用COM組件,添加excel的com對(duì)象Microsoft Excel 11.0 Object,然后在引用中可以看到
Microsoft.Office.Core,Excel,VBIDE三個(gè)對(duì)象。此時(shí)在程序中需要引入:
using System.Reflection;
using Microsoft.Office.Core;
using Microsoft.Office.Interop.Excel;
基本的操作方式:
?? Application excel = new ApplicationClass();
??????????????? excel.Visible = false;
??????????????? Workbook wb = excel.Workbooks._Open(modelFile, Missing.Value, Missing.Value, Missing.Value, Missing.Value
??????????????????? , Missing.Value, Missing.Value, Missing.Value, Missing.Value
??????????????????? , Missing.Value, Missing.Value, Missing.Value, Missing.Value);
??????????????? Worksheet xSheet = (Worksheet)wb.Sheets[1];
??????? //Sheets sts = wb.Worksheets;
??????? //_Worksheet st = (_Worksheet)sts.get_Item(1);
??????? //st.Cells[3, 5] = "111"; //直接在cell上寫(xiě)值
??????? //st.Cells[2, 5] = "hahaha";
??????????????? Range range = xSheet.get_Range("A3", "H3");
??????????????? object[] objLines = { a200.Date, a200.PreviousClosePrice, a200.OpenPrice, a200.High, a200.Low, a200.Close, a200.Change, a200.ChangeRate };
??????????????? range.set_Value(Missing.Value, objLines);
??????????????? wb.SaveAs(fileName, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, XlSaveAsAccessMode.xlNoChange,
??????????????????? Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
??????????????? //wb.Close(false, Missing.Value, Missing.Value);
//以下步驟必須進(jìn)行,否則Excel在進(jìn)程里不能自動(dòng)釋放
??????????????? NAR(range);
??????????????? NAR(xSheet);
??????????????? wb.Close(false, Missing.Value, Missing.Value);
??????????????? NAR(wb);????????????????????
??????????????? excel.Quit();
??????????????? NAR(excel);
??????????????? System.GC.Collect();
//以往的做法是將進(jìn)程里所以的Excel進(jìn)程Kill掉,不推薦!
private void NAR(object o)
??????? {
??????????? try
??????????? {
??????????????? System.Runtime.InteropServices.Marshal.ReleaseComObject(o);//強(qiáng)制釋放一個(gè)對(duì)象
??????????? }
??????????? catch { }
??????????? finally
??????????? {
??????????????? o = null;
??????????? }
??????? }
二. 通過(guò)OLEDB操作Excel
???? OleDbConnection conn = null;
??????????? try
??????????? {
????????????? //fileName 表示要操縱的Excel的文件路徑,如果excel不存在,現(xiàn)創(chuàng)建它,可以通過(guò)模版文件復(fù)制創(chuàng)建。
??????????????? string strConn;
??????????????? strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +
??????????????? "Data Source=" + fileName + ";" +
??????????????? "Extended Properties='Excel 8.0;HDR=no;IMEX=0'";
??????????????? conn = new OleDbConnection(strConn);
??????????????? conn.Open();
??????????????? System.Data.OleDb.OleDbCommand cmd = new System.Data.OleDb.OleDbCommand();
??????????????? cmd.Connection = conn;
??????????????? //在Excel的Sheet1的A3到H3處插入數(shù)據(jù)
??????????????? cmd.CommandText = "insert into [Sheet1$A3:H3] (F1,F2,F3,F4,F5,F6,F7,F8) values('" + a200.Date + "','"
??????????????????? + a200.PreviousClosePrice + "','" + a200.OpenPrice + "','" + a200.High + "','" + a200.Low + "','" + a200.Close + "','" +
??????????????????? a200.Change + "','" + a200.ChangeRate + "')";
??????????????? cmd.ExecuteNonQuery();
??????????????? conn.Close();
??????????? }
??????????? catch (Exception e)
??????????? {
??????????????? if (conn != null)
??????????????????? conn.Close();
??????????????? Console.WriteLine(e.ToString());
??????????? }
注:
1)使用 Excel 工作簿時(shí),默認(rèn)情況下,區(qū)域中的第一行是標(biāo)題行(或字段名稱(chēng))。如果第一個(gè)區(qū)域不包含標(biāo)題,您可以在連接字符串的擴(kuò)展屬性中指定 HDR=NO。
如果您在連接字符串中指定 HDR=NO,Jet OLE DB 提供程序?qū)⒆詣?dòng)為您命名字段(F1 表示第一個(gè)字段,F2 表示第二個(gè)字段,依此類(lèi)推);
2)IMEX=1將所有讀入數(shù)據(jù)
看作字符,其他值(0、2)請(qǐng)查閱相關(guān)幫助文檔;3)如果出現(xiàn)“找不到可安裝的isam”錯(cuò)誤,一般是連接字符串錯(cuò)誤。
3、從excel文件讀取數(shù)據(jù)
string sql = "select * from [sheet1$]";
DoOleSql(sql,"test.xls");
4、更新excel文件中的數(shù)據(jù)
string sql = "update [sheet1$] set FieldName1='333' where FieldName2='b3'";
DoOleSql(sql,"test.xls");
5、向excel文件插入數(shù)據(jù)
string sql = "insert into [sheet1$](FieldName1,FieldName2,…) values('a',’b’,…)";
DoOleSql(sql,"test.xls");
6、刪除excel文件中的數(shù)據(jù):不提倡使用這種方法
7、對(duì)于非標(biāo)準(zhǔn)結(jié)構(gòu)的excel表格,可以指定excel中sheet的范圍
1)讀取數(shù)據(jù):string sql = "select * from [sheet1$A3:F20]";
2)更新數(shù)據(jù):string sql = "update [sheet1$A9:F15] set FieldName='333' where AnotherFieldName='b3'";
3)插入數(shù)據(jù):string sql = "insert into [sheet1$A9:F15](FieldName1,FieldName2,…) values('a',’b’,…)";
4)刪除數(shù)據(jù):不提倡
注:1)代碼根據(jù)需要可以自行修改;2)如果出現(xiàn)“操作必須使用一個(gè)可更新的查詢(xún)”錯(cuò)誤,可能sql語(yǔ)句中對(duì)excel文件中的“字段”引用有錯(cuò)誤,或?qū)xcel文件不
具有“修改”權(quán)限;3)如果出現(xiàn)“不能擴(kuò)充選定范圍”錯(cuò)誤,可能是對(duì)excel文件引用的“范圍”有錯(cuò)誤。
轉(zhuǎn)載于:https://www.cnblogs.com/net-study/p/3708558.html
總結(jié)
以上是生活随笔為你收集整理的C#操作Excel文件(转)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: WinPcap编程入门实践
- 下一篇: C# HashTable 使用用法详解