欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#利用XML創(chuàng)建Excel文檔的實(shí)現(xiàn)方法

 更新時間:2014年08月12日 12:08:30   投稿:shichen2014  
這篇文章主要介紹了C#利用XML創(chuàng)建Excel文檔的實(shí)現(xiàn)方法,需要的朋友可以參考下

一般來說C#在不安裝Excel軟件的情況下,可以通過XML來創(chuàng)建Excel文檔。因此,運(yùn)行本文所述代碼您無需安裝Excel程序。本文原例子是使用VB.Net寫的,以下的用C#改寫的代碼,分享給大家,供大家參考。

具體代碼如下:

DataSet mDSData = new DataSet();
mDSData.Tables.Add("myTable");
mDSData.Tables["myTable"].Columns.Add("ID");
mDSData.Tables["myTable"].Columns.Add("Name");
mDSData.Tables["myTable"].Columns.Add("PassWord");
for (int i = 0; i < 10; i++)
{
  DataRow dr = mDSData.Tables["myTable"].NewRow();
  dr["ID"] = i;
  dr["Name"] = i;
  dr["PassWord"] = i;
  mDSData.Tables["myTable"].Rows.Add(dr);
}
SaveFileDialog dialog1 = new SaveFileDialog();
dialog1.AddExtension = true;
dialog1.CheckPathExists = true;
dialog1.Filter = "Excel Workbooks (*.xls) | *.xls";
dialog1.OverwritePrompt = true;
dialog1.Title = "Save Excel Formatted Report";
if (dialog1.ShowDialog() == DialogResult.OK)
{
  int num2 = 0;
  int num3 = mDSData.Tables[0].Rows.Count + 1;
  int num1 = mDSData.Tables[0].Columns.Count;
  num2 = 0;
  string text1 = dialog1.FileName;
  if (File.Exists(text1))
  {
    File.Delete(text1);
  }
  StreamWriter writer1 = new StreamWriter(text1, false);
  StreamWriter writer2 = writer1;
  writer2.WriteLine("<?xml version=\"1.0\"?>");
  writer2.WriteLine("<?mso-application progid=\"Excel.Sheet\"?>");
  writer2.WriteLine("<Workbook xmlns=\"urn:schemas-microsoft-com:office:spreadsheet\"");
  writer2.WriteLine(" xmlns:o=\"urn:schemas-microsoft-com:office:office\"");
  writer2.WriteLine(" xmlns:x=\"urn:schemas-microsoft-com:office:excel\"");
  writer2.WriteLine(" xmlns:ss=\"urn:schemas-microsoft-com:office:spreadsheet\"");
  writer2.WriteLine(" xmlns:html=\"http://www.w3.org/TR/REC-html40\">");
  writer2.WriteLine(" <DocumentProperties xmlns=\"urn:schemas-microsoft-com:office:office\">");
  writer2.WriteLine(" <Author>Automated Report Generator Example</Author>");
  writer2.WriteLine(string.Format(" <Created>{0}T{1}Z</Created>", DateTime.Now.ToString("yyyy-mm-dd"), DateTime.Now.ToString("HH:MM:SS")));
  writer2.WriteLine(" <Company>Your Company Here</Company>");
  writer2.WriteLine(" <Version>11.6408</Version>");
  writer2.WriteLine(" </DocumentProperties>");
  writer2.WriteLine(" <ExcelWorkbook xmlns=\"urn:schemas-microsoft-com:office:excel\">");
  writer2.WriteLine(" <WindowHeight>8955</WindowHeight>");
  writer2.WriteLine(" <WindowWidth>11355</WindowWidth>");
  writer2.WriteLine(" <WindowTopX>480</WindowTopX>");
  writer2.WriteLine(" <WindowTopY>15</WindowTopY>");
  writer2.WriteLine(" <ProtectStructure>False</ProtectStructure>");
  writer2.WriteLine(" <ProtectWindows>False</ProtectWindows>");
  writer2.WriteLine(" </ExcelWorkbook>");
  writer2.WriteLine(" <Styles>");
  writer2.WriteLine(" <Style ss:ID=\"Default\" ss:Name=\"Normal\">");
  writer2.WriteLine("  <Alignment ss:Vertical=\"Bottom\"/>");
  writer2.WriteLine("  <Borders/>");
  writer2.WriteLine("  <Font/>");
  writer2.WriteLine("  <Interior/>");
  writer2.WriteLine("  <Protection/>");
  writer2.WriteLine(" </Style>");
  writer2.WriteLine(" <Style ss:ID=\"s21\">");
  writer2.WriteLine("  <Alignment ss:Vertical=\"Bottom\" ss:WrapText=\"1\"/>");
  writer2.WriteLine(" </Style>");
  writer2.WriteLine(" </Styles>");
  writer2.WriteLine(" <Worksheet ss:Name=\"MyReport\">");
  writer2.WriteLine(string.Format(" <Table ss:ExpandedColumnCount=\"{0}\" ss:ExpandedRowCount=\"{1}\" x:FullColumns=\"1\"", num1.ToString(), num3.ToString()));
  writer2.WriteLine("  x:FullRows=\"1\">");
  foreach (DataRow row1 in mDSData.Tables[0].Rows)
  {
    writer2.WriteLine("<Row>");
    for (num2 = 0; num2 != num1; num2++)
    {
      writer2.Write("<Cell ss:StyleID=\"s21\"><Data ss:Type=\"String\">");
      writer2.Write(row1[num2].ToString());
      writer2.WriteLine("</Data></Cell>");
    }
    writer2.WriteLine("</Row>");
  }
  writer2.WriteLine(" </Table>");
  writer2.WriteLine(" <WorksheetOptions xmlns=\"urn:schemas-microsoft-com:office:excel\">");
  writer2.WriteLine("  <Selected/>");
  writer2.WriteLine("  <Panes>");
  writer2.WriteLine("  <Pane>");
  writer2.WriteLine("   <Number>3</Number>");
  writer2.WriteLine("   <ActiveRow>1</ActiveRow>");
  writer2.WriteLine("  </Pane>");
  writer2.WriteLine("  </Panes>");
  writer2.WriteLine("  <ProtectObjects>False</ProtectObjects>");
  writer2.WriteLine("  <ProtectScenarios>False</ProtectScenarios>");
  writer2.WriteLine(" </WorksheetOptions>");
  writer2.WriteLine(" </Worksheet>");
  writer2.WriteLine(" <Worksheet ss:Name=\"Sheet2\">");
  writer2.WriteLine(" <WorksheetOptions xmlns=\"urn:schemas-microsoft-com:office:excel\">");
  writer2.WriteLine("  <ProtectObjects>False</ProtectObjects>");
  writer2.WriteLine("  <ProtectScenarios>False</ProtectScenarios>");
  writer2.WriteLine(" </WorksheetOptions>");
  writer2.WriteLine(" </Worksheet>");
  writer2.WriteLine(" <Worksheet ss:Name=\"Sheet3\">");
  writer2.WriteLine(" <WorksheetOptions xmlns=\"urn:schemas-microsoft-com:office:excel\">");
  writer2.WriteLine("  <ProtectObjects>False</ProtectObjects>");
  writer2.WriteLine("  <ProtectScenarios>False</ProtectScenarios>");
  writer2.WriteLine(" </WorksheetOptions>");
  writer2.WriteLine(" </Worksheet>");
  writer2.WriteLine("</Workbook>");
  writer2 = null;
  writer1.Close();
  MessageBox.Show("Report Created", "Success", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
}

這只是主要的代碼,使用前需要此入using相應(yīng)的命名空間,如果不知道需要哪個命名空間,可在編譯時根據(jù)提示逐個添加。

相關(guān)文章

  • c#哈希算法的實(shí)現(xiàn)方法及思路

    c#哈希算法的實(shí)現(xiàn)方法及思路

    這篇文章主要介紹了c#哈希算法的實(shí)現(xiàn)方法及思路,有需要的朋友可以參考一下
    2013-12-12
  • C# 一個WCF簡單實(shí)例

    C# 一個WCF簡單實(shí)例

    以訂票為例簡單應(yīng)用wcf程序,需要的朋友可以參考下
    2012-10-10
  • 淺析C#中不同格式請求的區(qū)別

    淺析C#中不同格式請求的區(qū)別

    form-data?請求和?x-www-form-urlencoded?請求是兩種常見的?HTTP?請求體格式,這篇文章主要為大家詳細(xì)介紹了二者的區(qū)別與應(yīng)用,希望對大家有所幫助
    2023-08-08
  • 詳解C#如何為某個方法設(shè)定執(zhí)行超時時間

    詳解C#如何為某個方法設(shè)定執(zhí)行超時時間

    這篇文章主要為大家詳細(xì)介紹一下C#如何為某個方法設(shè)定執(zhí)行超時時間,文中的示例代碼簡潔易懂,具有一定的借鑒價(jià)值,有需要的小伙伴可以學(xué)習(xí)一下
    2023-10-10
  • c#使用file.copy實(shí)現(xiàn)文件備份示例

    c#使用file.copy實(shí)現(xiàn)文件備份示例

    需要把D盤Source文件夾中的所有名稱包含"LTE"的子文件夾Copy到E盤的Backup文件中,實(shí)現(xiàn)特定文件夾每天備份,下面使用file.copy實(shí)現(xiàn)一下這個功能
    2014-03-03
  • 聊聊C#中的Mixin的具體用法

    聊聊C#中的Mixin的具體用法

    本文主要介紹了C#中的Mixin的具體用法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • c#檢測usb設(shè)備撥插類庫USBClassLibrary分享

    c#檢測usb設(shè)備撥插類庫USBClassLibrary分享

    這篇文章主要介紹了c#檢測usb設(shè)備撥插類庫USBClassLibrary的簡單示例,需要的朋友可以參考下
    2014-04-04
  • C#學(xué)習(xí)進(jìn)階Hello World的17種寫法代碼分享

    C#學(xué)習(xí)進(jìn)階Hello World的17種寫法代碼分享

    本文針對不同階段、不同程度的C#學(xué)習(xí)者,介紹了C# Hello World的17種不同寫法,C# Hello World寫法入門、C# Hello World寫法進(jìn)階、C# Hello World的特別寫法三種角度進(jìn)行推進(jìn)
    2013-12-12
  • C# 面向?qū)ο蟮幕驹瓌t

    C# 面向?qū)ο蟮幕驹瓌t

    什么是面向?qū)ο蟮幕驹瓌t?設(shè)計(jì)原則是基本的工具,應(yīng)用這些規(guī)則可以使你的代碼更加靈活、更容易維護(hù),更容易擴(kuò)展。
    2009-11-11
  • C#實(shí)現(xiàn)DevExpress本地化實(shí)例詳解

    C#實(shí)現(xiàn)DevExpress本地化實(shí)例詳解

    這篇文章主要介紹了C#實(shí)現(xiàn)DevExpress本地化,以實(shí)例形式較為詳細(xì)的分析了DevExpress本地化的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08

最新評論