[習題]輸出成Excel,並且有多個工作表(Work Sheet)

輸出成Excel,並且有多個工作表(Work Sheet)
Excel 2003當我們另存新檔,會有一個「Excel XML」檔的選項。

Excel 2003當我們另存新檔,會有一個「Excel XML」檔的選項。
存檔後,XML格式如下:



如果XML碼看不清楚的話,到我網站去看看 http://www.taconet.com.tw/mis2000_aspnet/ASP_NET20.htm#22_excel

<?xml version="1.0"?>
<?mso-application progid="Excel.Sheet"?>
<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet"
xmlns:o="urn:schemas-microsoft-com:office:office"
xmlns:x="urn:schemas-microsoft-com:office:excel"
xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet"
xmlns:html="http://www.w3.org/TR/REC-html40">


<Worksheet ss:Name="Sheet1">
  <Table ss:ExpandedColumnCount="2" ss:ExpandedRowCount="3" x:FullColumns="1"
  x:FullRows="1" ss:DefaultColumnWidth="54" ss:DefaultRowHeight="16.5">
  <Row>
      <Cell><Data ss:Type="Number">1</Data></Cell>
      <Cell><Data ss:Type="String">aaa</Data></Cell>
  </Row>
  <Row>
      <Cell><Data ss:Type="Number">2</Data></Cell>
      <Cell><Data ss:Type="String">bbb</Data></Cell>
  </Row>
  <Row>
      <Cell><Data ss:Type="Number">3</Data></Cell>
      <Cell><Data ss:Type="String">ccc</Data></Cell>
  </Row>
  </Table>
<WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">
   <ProtectObjects>False</ProtectObjects>
   <ProtectScenarios>False</ProtectScenarios>
</WorksheetOptions>
</Worksheet>

<Worksheet ss:Name="Sheet2">
<Table ss:ExpandedColumnCount="0" ss:ExpandedRowCount="0" x:FullColumns="1"
x:FullRows="1" ss:DefaultColumnWidth="54" ss:DefaultRowHeight="16.5"/>
<WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">
<ProtectObjects>False</ProtectObjects>
<ProtectScenarios>False</ProtectScenarios>
</WorksheetOptions>
</Worksheet>

<Worksheet ss:Name="Sheet3">
<Table ss:ExpandedColumnCount="0" ss:ExpandedRowCount="0" x:FullColumns="1"
x:FullRows="1" ss:DefaultColumnWidth="54" ss:DefaultRowHeight="16.5"/>
<WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">
<ProtectObjects>False</ProtectObjects>
<ProtectScenarios>False</ProtectScenarios>
</WorksheetOptions>
</Worksheet>
</Workbook>



看看上面的XML碼,您就知道不同的 Work Sheet該怎麼作了。
把資料庫裡面的資料,透過XML排版,就能把結果輸出成 Excel檔案。

而且有多個 Work Sheet

 

 

透過 Jet.OLEDB 讀取 Excel裡面的資料 

 

真正的好東西來了~~[轉貼]在 Server 端存取 Excel 檔案的利器:NPOI Library  (2010/1/13補充)

 

2008/8/6補充:如果這些報表,是定期產生的(例如每天一次、或兩次),我會建議直接從資料庫去作,也滿簡單的。

  • MS SQL Server 2000有一個DTS功能,可以固定產生報表。輸出到檔案、Excel等等檔案、或是輸出到其他資料庫。
  • MS SQL Server 2005把DTS改名為SSIS。搭配Visual Studio 2005有一個設計介面(名為BIDS,Business Intelligence Development Studio),拉幾個流程,就能完成這些所謂的資料轉換、轉成Excel或Access的煩人工作。

 

 
 

我將思想傳授他人, 他人之所得,亦無損於我之所有;

猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----Thomas Jefferson

寫信給我--  mis2000lab (at) yahoo.com.台灣  或是  school (at) mis2000lab.net

................   facebook社團   https://www.facebook.com/mis2000lab   ......................

................   Google+   https://plus.google.com/100202398389206570368/posts ........

................  YouTube (ASP.NET) 線上教學影片  http://goo.gl/rGLocQ

Blog文章 "附的範例" 無法下載,請看 這裡 ...... https://dotblogs.com.tw/mis2000lab/2016/03/14/2008_2015_mis2000lab_sample_download

請看我們的「售後服務」範圍(嚴格認定)

......................................................................................................................................................

......................................................................................................................................................

  從頭學起、學習 [各種]控制項,瞭解ASP.NET生命週期與變革,請上這一班:        

ASP.NET 遠距教學,「線上直播」免出門,在家上課   上課時,老師 親自 線上講解!並非事先錄影!    

 

[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!微軟MVP --MIS2000Lab.主講

事先錄製好的影片,並非上課時側錄!   觀看影片時,有如我「一對一」跟您面對面講課

 

    MIS2000 Lab.  線上教學影片(YouTube) **免費觀賞**