C#操作Excel文件(转)
關鍵詞:受管代碼;非受管代碼;Excel對象;動態連接庫
引言
Excel是微軟公司辦公自動化套件中的一個軟件,他主要是用來處理電子表格。 Excel以其功能強大,界面友好等受到了許多用戶的歡迎。在設計應用系統時,對于不同的用戶,他們對于打印的需求是不一樣的,如果要使得程序中的打印功 能適用于每一個用戶,可以想象程序設計是十分復雜的。由于Excel表格的功能強大,又由于幾乎每一臺機器都安裝了它,如果把程序處理的結果放到 Excel表格中,這樣每一個用戶就可以根據自己的需要在Excel中定制自己的打印。這樣不僅使得程序設計簡單,而且又滿足了諸多用戶的要求,更加實用 了。那么用Visual C#如何調用Excel,如何又把數據存放到Excel表格中?本文就來探討上述問題的解決辦法。
Excel對象
微軟的Excel對象模型包括了128個不同的對象,從矩形,文本框等簡單的對象到透視表,圖表等復雜的對象.下面我們簡單介紹一下其中最重要,也是用得最多的四個對象。
(1) Application對象。Application對象處于Excel對象層次結構的頂層,表示Excel自身的運行環境。
(2) Workbook對象。Workbook對象直接地處于Application對象的下層,表示一個Excel工作薄文件。
(3) Worksheet對象。Worksheet對象包含于Workbook對象,表示一個Excel工作表。
(4) Range對象。Range對象包含于Worksheet對象,表示Excel工作表中的一個或多個單元格。
C#中的受管代碼和非受管代碼
在.net公用語言框架內運行的程序為受管代碼。受管代碼在程序中所有類型都受到嚴格檢 查,沒有指針,對內存的管理完全由運行系統控制。受控狀態下,編寫程序更為容易,且更少出錯,我們可以花更多的時間在解決實際問題上而不是在計算機語言問 題上。相對而言,那些在.NET框架外運行的程序為非受管代碼。比如:COM組件、ActiveX組件、Win32 API函數、指針運算等。C#編程中在某些特定情況下,需要運用非受管代碼,例如,要利用一個成熟的COM組件,或者調用一個API函數,或者用指針去編 寫實時/高效程序等。
Visual C#中調用Excel的COM組件
一個.NET組件事實上是一個.NET下的DLL,它包含的不僅是運行程序本身,更重要的是包含這個DLL的描述信息(Meta Data,即元數據),而一個COM組件是用其類庫(TLB)儲存其描述信息。這些COM組件都是非受管代碼,要在Visual C#中使用這些非受管代碼的COM組件,就必須把他們轉換成受管代碼的.NET組件。所以在用Visual C#調用Excel表格之前,必須完成從COM組件的非受管代碼到受管代碼的類庫的轉換。
1、將Excel的COM組件轉換為.NET組件
在項目中打開Add Reference對話框,選擇COM欄,之后在COM列表中找到"Microsoft Excel 9.0 Object Library"(Office 2000),然后將其加入到項目的References中即可。Visual C#.NET會自動產生相應的.NET組件文件,以后即可正常使用。
這個轉換形成.NET組件不能單獨使用,它不過是以前的COM組件的一個外層包裝,在.NET中可以通過這個外層包裝去發現原來的COM組件并調用其相應的界面函數。所以它必須與原來的COM組件一起起作用。
2、Visual C#打開Excel表格
事實上,在C#中使用一個經轉換的COM組件和使用任何一個其它.NET組件完全一樣。可以用new關鍵字創建一個經轉換的COM組件,然后再像使用任何一個其它C#對象一樣使用這個組件對象。
在轉換后的.NET組件中定義了一個命名空間Excel,在此命名空間中封裝了一個類Application,這個類和啟動Excel表格有非常重要的關系,在Visual C#中,只需要下列三行代碼就可以完成打開Excel表格的工作,具體如下:
| Excel.Application excel = new Excel.Application ();//引用Excel對象 excel.Application.Workbooks.Add ( true );//引用Excel工作簿 excel.Visible = true ;//使Excel可視 |
但此時的Excel表格是一個空的表格,沒有任何內容,下面就來介紹如何往Excel表格中輸入數據。
3、往Excel表格中輸入數據
在命名空間"Excel"中,還定義了一個類"Cell",這個類所代表的就是Excel表格中的一個單元格。通過給"Cell"賦值,從而實現往Excel表格中輸入相應的數據,下列代碼功能是打開Excel表格,并且往表格輸入一些數據。
| 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、實例
下面實例在C#中連接Oracle數據庫(Name),從表(TableName)中讀取數據,并寫入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、安裝一個使用COM組件的.net程序
如果要將這樣的程序安裝運行在另一臺機器上,那么除了安裝運行程序外,還做三件事。
首先,是安裝.NET運行系統。因為任何一個.NET程序都不能離開.NET運行系統去獨立運行。
其次,所調用的COM組件必須要安裝在目標機器上。本例中大多數目標機器上都裝有Microsoft Office的Excel,一般不會有這個問題。但如果是另一個用戶自定義的COM組件,那么這個COM組件在運行.NET程序之前必須先安裝好。
最后,轉換后的.NET組件DLL文件要安裝在目標機器上。因為.NET組件不需要在Windows ReGIStry中注冊,所以最簡單的方法是將.NET組件DLL文件拷貝到運行程序目錄下。如果此.NET組件被多個.NET程序共享,可以將其安裝在.NET公用組件區中,從而可被任何一個.NET組件使用。只有當一個.NET組件參與了事務處理時,才需要將它注冊為一個COM+組件。因為.NET仍然用傳統的COM+機制來處理事務的提交、回滾等。
小結
通過以上討論,我們知道了在C#中,如何使用Excel的COM組件。需要注意的是,Excel對象包含的許多內容我們沒有介紹,在使用過程中需要我們不斷學習。也使我們了解了在C#中如何使用COM組件。
參考文獻:
[1] 劉洪成 C#高級編程 清華大學出版社 2003.7工作 187~200
====================================================================================
| ||||||
| ? | 前些日子,有很多朋友說需要C#導出到Excel的代碼,現共享給大家 /// <summary> /// <summary> 這種方法目前最有效,如果有不明白的地方可以來信交流 ? 作者Blog:http://blog.csdn.net/lovelyxc/ |
====================================================================================
首先將excel.exe copy 到 ..\Microsoft Visual Studio .NET 2003\SDK\v1.1\Bin目錄下
利用.net 中帶的工具在命令提示符下執行tlbimp excel.exe.這樣就不會因為你的Excel是xp或2000的不同要去找不同的*.olb文件,還有一點就是因為在2000以后的版本中沒有了excel9.olb這個文件了。
通過執行tlbimp excel.exe后我們會得到excel.dll文件。
只要有了這個Excel.dll,現在我們就能使用Excel的各種操作函數了。
下面就讓我們具體看看C#是如何使用這些東東吧。
1. 創建一個新Excel的Application:
Application exc = new Application();
if (exc == null) {
Console.WriteLine("ERROR: EXCEL couldn't be started");
return 0;
}
2. 讓這個工程可見:
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. 給單元格設置變量:
?
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;
}
}
現在我們來看看如何使用數組,他有些類似于設置單元格。僅僅需要的改變只是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這個工具的使用啊:)這個東東很有用,可以將普通Win32程序移植到.Net下面來:)
如果操作的excel的格式很簡單,就是一般的表的結構,那么其實操作EXCEL文件跟操作ACCESS數據庫文件的方法幾乎一樣。
(需要注意的地方就是,1、程序會把EXCLE表中的第一行記錄作為列名;2、在使用EXCLE表的時候, 要在表名后面加上符號$)
下面,我給你帖一段如何連接和讀取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是一個DataGrid控件
dg1.DataBind();??//將EXCLE中股票代碼中的記錄棒定到DataGrid控件上
如果是在asp.net 下使用的話,要記得在? <system.web>中添加<identity impersonate="true"/>
否則就會出現 “異常詳細信息: System.UnauthorizedAccessException: 拒絕訪問“。
=======================================================
一、調用Excel的方法:一般情況下有兩種方法調用Excel:
1、 ?直接使用Delphi自帶的組件:在Form中分別放入ExcelApplication, ExcelWorkbook和ExcelWorksheet。
2、動態創建Excel文件:首先創建 Excel 對象,使用ComObj,Excel2000:
var ExcelApp: Variant;
ExcelApp := CreateOleObject( 'Excel.Application' );
二、導入數據:在程序中,我們可以將查詢到的數據(SQL、Access、)導入到Excel中。例如:用Adoquery查詢Access中的數據:
1、先查到所需的數據;
2、導入:i:=1;
Adoquery.First;
? ? ? ? ? ? ? while not Adoquery.Eof do
? ? ? ? ? ? ? ? Begin
? ? ? ? ? ? ? ? ? ExcelApp.WorkSheets[1].Cells[i,1].Value := i;//添加序號的值
ExcelApp.WorkSheets[1].Cells[i,2].Value := Adoquery.FieldByName('cp_name').AsString;
? ? ? ? ? ? ? ? ? ……
? ? ? ? ? ? ? ? ? Inc(i);
Adoquery.Next;
? ? ? ? ? ? ? ? End;
當然也可以把Adotable、Adoquery、Table、Query等組件的數據導入到Excel中。
三、Excel的處理:如果在你已知Excel格式的情況下,可以控制Excel,如下:
1、 顯示當前窗口:ExcelApp.Visible := True;
2、 更改 Excel 標題欄:ExcelApp.Caption := '標題內容';
3、 添加新工作簿:ExcelApp.WorkBooks.Add;
4、 設置第2個工作表為活動工作表:ExcelApp.WorkSheets[2].Activate;
5、 給單元格賦值:ExcelApp.Cells[1,1].Value := '第一行第一列';
6、 設置指定列的寬度(單位:字符個數),以第一列為例:
ExcelApp.ActiveSheet.Columns[1].ColumnsWidth := 5;
7、 設置指定行的高度(單位:磅)(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行之前插入分頁符:ExcelApp.WorkSheets[1].Rows[8].PageBreak := 1;
15、在第4列之前刪除分頁符:ExcelApp.ActiveSheet.Columns[4].PageBreak := 0;
16、指定邊框線寬度:ExcelApp.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3;
1-左 ? ?2-右 ? 3-頂 ? ?4-底 ? 5-斜( \ ) ? ? 6-斜( / )
17、拷貝操作:a.拷貝整個工作表:ExcelApplication1.ActiveSheet.Used.Range.Copy;
b.拷貝指定區域:ExcelApplication1.ActiveSheet.Range[ 'A1:E2' ].Copy;
? ? ? ? ? ? ? ? ?c.從A1位置開始粘貼:ExcelApplication1.ActiveSheet.Range.[ 'A1' ].PasteSpecial;
d.從文件尾部開始粘貼: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、放棄存盤:ExcelApp.ActiveWorkBook.Saved := True;
22、關閉工作簿:ExcelApp.WorkBooks.Close;
23、退出 Excel:ExcelApp.Quit;
下面是有關打印頁面控制的語句:
? ?24、設置第一行字體屬性:ExcelApp.ActiveSheet.Rows[1].Font.Name := '隸書';
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、進行頁面設置:a.頁眉:ExcelApp.ActiveSheet.PageSetup.CenterHeader := '報表演示';
b.頁腳:ExcelApp.ActiveSheet.PageSetup.CenterFooter := '共&N頁 第&P頁';
? ? ? ? ? ? ? ? ? ? ?c.頁眉到頂端邊距2cm:ExcelApp.ActiveSheet.PageSetup.HeaderMargin := 2/0.035;
d.頁腳到底端邊距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.頁面水平居中:ExcelApp.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035;
j.頁面垂直居中:ExcelApp.ActiveSheet.PageSetup.CenterVertically := 2/0.035;
? ? ? ? ? ? ? ? ? ? ?k.打印單元格網線:ExcelApp.ActiveSheet.PageSetup.PrintGridLines := True;
26、打印預覽工作表:ExcelApp.ActiveSheet.PrintPreview;
27、打印輸出工作表:ExcelApp.ActiveSheet.PrintOut;
對Excel的其他控制:
28、excel的多單元格合計功能:ExcelApp..Cells[ARow, ACol].Formula
:= '= SUM($+IntToStr(BeginRow) +:$ + IntToStr(EndRow) +');
注:聲明變量ARow, ACol: Integer;
29、打開已經存在的Excel文件: ExcelApplication1.Workbooks.Open (c:\a.xls
EmptyParam,EmptyParam,EmptyParam,EmptyParam,
EmptyParam,EmptyParam,EmptyParam,EmptyParam,
? ?EmptyParam,EmptyParam,EmptyParam,EmptyParam,0);
| ? | 查看評語???? ? |
?2004-3-4 16:41:04? ? 舉例來說
二、選擇excel表'按鈕,用于打開EXCEL文件,其代碼如下:
procedure TForm1.Button1Click(Sender: TObject);
var i,j:integer;
begin
opendialog1.InitialDir:=ExtractFileDir(paramstr(0));//文件的打存放初始路徑
opendialog1.Execute;
Try
ExcelApplication1.Connect;//EXCEL應用程序
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);//打開指定的EXCEL 文件
except
begin
ExcelApplication1.Disconnect;//出現異常情況時關閉
ExcelApplication1.Quit;showmessage('請選擇EXCEL電子表格!');
exit;
end;
end;
ExcelWorkbook1.ConnectTo(ExcelApplication1.Workbooks[1]);//ExcelWorkbook1與Eexcelapplication1建立連接
ExcelWorksheet1.ConnectTo(ExcelWorkbook1.Worksheets[1] as _Worksheet);//Excelworksheet1與Excelworkbook1建立連接
//開始從EXCEL中取數,放到stringgrid1中,取完數后關閉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;
//將第一條數據賦給編輯框
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;
三、'下一條記錄'按鈕,完成記錄向下移動,代碼如下:
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中上下移動時代碼:
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; ? ? ?//臨時句柄變量。
?APalette:HPALETTE; ?//臨時變量。
?Stream1:TMemoryStream;//TBlobStream
?xx:tbitmap;
? ? ? ? ? ?Stream1:= TMemoryStream.Create;
? ? ? ? ? ?TBlobField(query.FieldByName('存儲圖片的字段')).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是當前活動的sheet頁
? ? ? ? ? ?myworksheet1.Paste;
end;
============================================================
各位兄弟:讀取EXCEL數據是有的麻煩,經過研究,已搞掂,C#的代碼如下,至于寫數據則較簡單: ?
? Excel.ApplicationClass ? excel=new ? Excel ? .ApplicationClass ? (); ?
? excel.Workbooks ? .Add(path);//打開麻煩,增加一個較好處理 ?
? 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的方法
一. 直接調用COM組件
(如excel 2003)引用COM組件,添加excel的com對象Microsoft Excel 11.0 Object,然后在引用中可以看到
Microsoft.Office.Core,Excel,VBIDE三個對象。此時在程序中需要引入:
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上寫值
??????? //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);
//以下步驟必須進行,否則Excel在進程里不能自動釋放
??????????????? NAR(range);
??????????????? NAR(xSheet);
??????????????? wb.Close(false, Missing.Value, Missing.Value);
??????????????? NAR(wb);????????????????????
??????????????? excel.Quit();
??????????????? NAR(excel);
??????????????? System.GC.Collect();
//以往的做法是將進程里所以的Excel進程Kill掉,不推薦!
private void NAR(object o)
??????? {
??????????? try
??????????? {
??????????????? System.Runtime.InteropServices.Marshal.ReleaseComObject(o);//強制釋放一個對象
??????????? }
??????????? catch { }
??????????? finally
??????????? {
??????????????? o = null;
??????????? }
??????? }
二. 通過OLEDB操作Excel
???? OleDbConnection conn = null;
??????????? try
??????????? {
????????????? //fileName 表示要操縱的Excel的文件路徑,如果excel不存在,現創建它,可以通過模版文件復制創建。
??????????????? 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處插入數據
??????????????? 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 工作簿時,默認情況下,區域中的第一行是標題行(或字段名稱)。如果第一個區域不包含標題,您可以在連接字符串的擴展屬性中指定 HDR=NO。
如果您在連接字符串中指定 HDR=NO,Jet OLE DB 提供程序將自動為您命名字段(F1 表示第一個字段,F2 表示第二個字段,依此類推);
2)IMEX=1將所有讀入數據
看作字符,其他值(0、2)請查閱相關幫助文檔;3)如果出現“找不到可安裝的isam”錯誤,一般是連接字符串錯誤。
3、從excel文件讀取數據
string sql = "select * from [sheet1$]";
DoOleSql(sql,"test.xls");
4、更新excel文件中的數據
string sql = "update [sheet1$] set FieldName1='333' where FieldName2='b3'";
DoOleSql(sql,"test.xls");
5、向excel文件插入數據
string sql = "insert into [sheet1$](FieldName1,FieldName2,…) values('a',’b’,…)";
DoOleSql(sql,"test.xls");
6、刪除excel文件中的數據:不提倡使用這種方法
7、對于非標準結構的excel表格,可以指定excel中sheet的范圍
1)讀取數據:string sql = "select * from [sheet1$A3:F20]";
2)更新數據:string sql = "update [sheet1$A9:F15] set FieldName='333' where AnotherFieldName='b3'";
3)插入數據:string sql = "insert into [sheet1$A9:F15](FieldName1,FieldName2,…) values('a',’b’,…)";
4)刪除數據:不提倡
注:1)代碼根據需要可以自行修改;2)如果出現“操作必須使用一個可更新的查詢”錯誤,可能sql語句中對excel文件中的“字段”引用有錯誤,或對excel文件不
具有“修改”權限;3)如果出現“不能擴充選定范圍”錯誤,可能是對excel文件引用的“范圍”有錯誤。
轉載于:https://www.cnblogs.com/net-study/p/3708558.html
總結
以上是生活随笔為你收集整理的C#操作Excel文件(转)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: WinPcap编程入门实践
- 下一篇: PHP (20140506)