亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

使用NOPI讀取Word、Excel文檔內容

2019-10-29 21:03:23
字體:
來源:轉載
供稿:網友

使用NOPI讀取Excel的例子很多,讀取Word的例子不多。

Excel的解析方式有多中,可以使用ODBC查詢,把Excel作為一個數據集對待。也可以使用文檔結構模型的方式進行解析,即解析Workbook(工作簿)、Sheet、Row、Column。

Word的解析比較復雜,因為Word的文檔結構模型定義較為復雜。解析Word或者Excel,關鍵是理解Word、Excel的文檔對象模型。

Word、Excel文檔對象模型的解析,可以通過COM接口調用,此類方式使用較廣。(可以錄制宏代碼,然后替換為對應的語言)

也可以使用XML模型解析,尤其是對于2007、2010版本的文檔的解析。

using NPOI.POIFS.FileSystem;using NPOI.SS.UserModel;using NPOI.XSSF.UserModel;using NPOI.XWPF.UserModel;using System;using System.Collections.Generic;using System.Configuration;using System.IO;using System.Text;namespace eyuan{  public static class NOPIHandler  {    /// <summary>    ///     /// </summary>    /// <param name="fileName"></param>    /// <returns></returns>    public static List<List<List<string>>> ReadExcel(string fileName)    {      //打開Excel工作簿      XSSFWorkbook hssfworkbook = null;      try      {        using (FileStream file = new FileStream(fileName, FileMode.Open, FileAccess.Read))        {          hssfworkbook = new XSSFWorkbook(file);        }      }      catch (Exception e)      {        LogHandler.LogWrite(string.Format("文件{0}打開失敗,錯誤:{1}", new string[] { fileName, e.ToString() }));      }      //循環Sheet頁      int sheetsCount = hssfworkbook.NumberOfSheets;      List<List<List<string>>> workBookContent = new List<List<List<string>>>();      for (int i = 0; i < sheetsCount; i++)      {        //Sheet索引從0開始        ISheet sheet = hssfworkbook.GetSheetAt(i);        //循環行        List<List<string>> sheetContent = new List<List<string>>();        int rowCount = sheet.PhysicalNumberOfRows;        for (int j = 0; j < rowCount; j++)        {          //Row(邏輯行)的索引從0開始          IRow row = sheet.GetRow(j);          //循環列(各行的列數可能不同)          List<string> rowContent = new List<string>();          int cellCount = row.PhysicalNumberOfCells;          for (int k = 0; k < cellCount; k++)          {            //ICell cell = row.GetCell(k);            ICell cell = row.Cells[k];            if (cell == null)            {              rowContent.Add("NIL");            }            else            {              rowContent.Add(cell.ToString());              //rowContent.Add(cell.StringCellValue);            }          }          //添加行到集合中          sheetContent.Add(rowContent);        }        //添加Sheet到集合中        workBookContent.Add(sheetContent);      }      return workBookContent;    }    /// <summary>    ///     /// </summary>    /// <param name="fileName"></param>    /// <returns></returns>    public static string ReadExcelText(string fileName)    {      string ExcelCellSeparator = ConfigurationManager.AppSettings["ExcelCellSeparator"];      string ExcelRowSeparator = ConfigurationManager.AppSettings["ExcelRowSeparator"];      string ExcelSheetSeparator = ConfigurationManager.AppSettings["ExcelSheetSeparator"];      //      List<List<List<string>>> excelContent = ReadExcel(fileName);      string fileText = string.Empty;      StringBuilder sbFileText = new StringBuilder();      //循環處理WorkBook中的各Sheet頁      List<List<List<string>>>.Enumerator enumeratorWorkBook = excelContent.GetEnumerator();      while (enumeratorWorkBook.MoveNext())      {        //循環處理當期Sheet頁中的各行        List<List<string>>.Enumerator enumeratorSheet = enumeratorWorkBook.Current.GetEnumerator();        while (enumeratorSheet.MoveNext())        {          string[] rowContent = enumeratorSheet.Current.ToArray();          sbFileText.Append(string.Join(ExcelCellSeparator, rowContent));          sbFileText.Append(ExcelRowSeparator);        }        sbFileText.Append(ExcelSheetSeparator);      }      //      fileText = sbFileText.ToString();      return fileText;    }    /// <summary>    /// 讀取Word內容    /// </summary>    /// <param name="fileName"></param>    /// <returns></returns>    public static string ReadWordText(string fileName)    {      string WordTableCellSeparator = ConfigurationManager.AppSettings["WordTableCellSeparator"];      string WordTableRowSeparator = ConfigurationManager.AppSettings["WordTableRowSeparator"];      string WordTableSeparator = ConfigurationManager.AppSettings["WordTableSeparator"];      //      string CaptureWordHeader = ConfigurationManager.AppSettings["CaptureWordHeader"];      string CaptureWordFooter = ConfigurationManager.AppSettings["CaptureWordFooter"];      string CaptureWordTable = ConfigurationManager.AppSettings["CaptureWordTable"];      string CaptureWordImage = ConfigurationManager.AppSettings["CaptureWordImage"];      //      string CaptureWordImageFileName = ConfigurationManager.AppSettings["CaptureWordImageFileName"];      //      string fileText = string.Empty;      StringBuilder sbFileText = new StringBuilder();      #region 打開文檔      XWPFDocument document = null;      try      {        using (FileStream file = new FileStream(fileName, FileMode.Open, FileAccess.Read))        {          document = new XWPFDocument(file);        }      }      catch (Exception e)      {        LogHandler.LogWrite(string.Format("文件{0}打開失敗,錯誤:{1}", new string[] { fileName, e.ToString() }));      }      #endregion      #region 頁眉、頁腳      //頁眉      if (CaptureWordHeader == "true")      {        sbFileText.AppendLine("Capture Header Begin");        foreach (XWPFHeader xwpfHeader in document.HeaderList)        {          sbFileText.AppendLine(string.Format("{0}", new string[] { xwpfHeader.Text }));        }        sbFileText.AppendLine("Capture Header End");      }      //頁腳      if (CaptureWordFooter == "true")      {        sbFileText.AppendLine("Capture Footer Begin");        foreach (XWPFFooter xwpfFooter in document.FooterList)        {          sbFileText.AppendLine(string.Format("{0}", new string[] { xwpfFooter.Text }));        }        sbFileText.AppendLine("Capture Footer End");      }      #endregion      #region 表格      if (CaptureWordTable == "true")      {        sbFileText.AppendLine("Capture Table Begin");        foreach (XWPFTable table in document.Tables)        {          //循環表格行          foreach (XWPFTableRow row in table.Rows)          {            foreach (XWPFTableCell cell in row.GetTableCells())            {              sbFileText.Append(cell.GetText());              //              sbFileText.Append(WordTableCellSeparator);            }            sbFileText.Append(WordTableRowSeparator);          }          sbFileText.Append(WordTableSeparator);        }        sbFileText.AppendLine("Capture Table End");      }      #endregion      #region 圖片      if (CaptureWordImage == "true")      {        sbFileText.AppendLine("Capture Image Begin");        foreach (XWPFPictureData pictureData in document.AllPictures)        {          string picExtName = pictureData.suggestFileExtension();          string picFileName = pictureData.GetFileName();          byte[] picFileContent = pictureData.GetData();          //          string picTempName = string.Format(CaptureWordImageFileName, new string[] { Guid.NewGuid().ToString() + "_" + picFileName + "." + picExtName });          //          using (FileStream fs = new FileStream(picTempName, FileMode.Create, FileAccess.Write))          {            fs.Write(picFileContent, 0, picFileContent.Length);            fs.Close();          }          //          sbFileText.AppendLine(picTempName);        }        sbFileText.AppendLine("Capture Image End");      }      #endregion      //正文段落      sbFileText.AppendLine("Capture Paragraph Begin");      foreach (XWPFParagraph paragraph in document.Paragraphs)      {        sbFileText.AppendLine(paragraph.ParagraphText);      }      sbFileText.AppendLine("Capture Paragraph End");      //      //      fileText = sbFileText.ToString();      return fileText;    }  }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97久久超碰福利国产精品…| 亚洲在线免费观看| 97**国产露脸精品国产| 久久国产精品亚洲| 成人疯狂猛交xxx| 亚洲一二在线观看| 国产999精品久久久影片官网| 欧美成年人视频| 懂色aⅴ精品一区二区三区蜜月| 久久中文字幕视频| 一区二区三区日韩在线| 精品动漫一区二区三区| 国内精品久久久久影院优| 国产日韩换脸av一区在线观看| 亚洲欧美国产高清va在线播| 成人黄色在线免费| 性色av一区二区三区| 国产成人综合一区二区三区| 欧美性极品少妇精品网站| 久久亚洲精品成人| 国产日韩在线亚洲字幕中文| 欧美成人精品激情在线观看| 日本久久久a级免费| 久久久久久久一区二区三区| 久久久天堂国产精品女人| 国产精品久久久久久婷婷天堂| 日韩欧美aⅴ综合网站发布| 一本色道久久88精品综合| 2025国产精品视频| 亚洲自拍偷拍视频| 日韩视频中文字幕| 日韩电影免费观看中文字幕| 亚洲欧美中文另类| 国产成人久久久| 欧美日韩在线观看视频| 国产男女猛烈无遮挡91| 91日韩在线视频| 欧美一级成年大片在线观看| 永久免费精品影视网站| 欧美性猛交xxxx黑人猛交| 在线观看不卡av| 欧美亚洲成人网| 91亚洲国产成人久久精品网站| 国产在线视频2019最新视频| 亚洲女人天堂视频| 一区二区三区日韩在线| 色中色综合影院手机版在线观看| 日韩在线观看免费av| 国产精品免费视频久久久| 色婷婷久久一区二区| 亚洲视频在线观看网站| 亚洲精品av在线播放| 国产小视频国产精品| 国产日韩在线一区| 97国产精品免费视频| 欧美日韩精品中文字幕| 国产ts人妖一区二区三区| 国产成人精品免费久久久久| 国产精品久久久久秋霞鲁丝| 精品久久久久国产| 亚洲欧美日韩在线一区| 97超碰蝌蚪网人人做人人爽| 日韩免费中文字幕| 欧美精品九九久久| 久久大大胆人体| 91精品国产91久久久久久最新| 精品福利在线观看| 国产精品免费久久久久久| 国产激情视频一区| 亚洲国产欧美自拍| 亚洲一级免费视频| 国内精品久久久久伊人av| 亚州精品天堂中文字幕| 91久久国产婷婷一区二区| 国产精品在线看| 欧美高清视频在线| 午夜剧场成人观在线视频免费观看| 日韩在线视频免费观看| 亚洲欧美在线一区| 国产精品免费久久久| 日韩免费视频在线观看| 精品久久久久久久久中文字幕| 中文字幕亚洲欧美日韩高清| 国产欧美精品一区二区三区介绍| 在线视频一区二区| 久久综合国产精品台湾中文娱乐网| 91av在线播放| 奇米成人av国产一区二区三区| 欧美有码在线观看| 国产精品久久9| 国产精品久久久久久久av电影| 亚洲毛片在线免费观看| 日本精品中文字幕| 最近2019年日本中文免费字幕| 欧美电影免费观看电视剧大全| 久久亚洲精品成人| 欧美性猛交xxxxx水多| 欧美在线观看日本一区| 色偷偷9999www| 国产精品久久久久久久天堂| 国产精品劲爆视频| 国产999精品久久久| 欧美在线视频一区| 久热在线中文字幕色999舞| 日韩成人av在线播放| 亚洲成人精品久久久| 欧美激情在线狂野欧美精品| 草民午夜欧美限制a级福利片| 国产一区二区三区高清在线观看| 神马国产精品影院av| 亚洲精品一区二区三区不| 美女啪啪无遮挡免费久久网站| 97精品一区二区三区| 日韩免费在线观看视频| 成人看片人aa| 蜜臀久久99精品久久久久久宅男| 日韩性生活视频| 成人444kkkk在线观看| 久久影院中文字幕| 精品日本美女福利在线观看| 欧美有码在线视频| 91精品视频在线免费观看| 国产成人精品综合| 日本久久久a级免费| 一区二区三区四区视频| 国产成人精品综合久久久| 亚洲石原莉奈一区二区在线观看| 高清欧美性猛交xxxx| 欧美专区第一页| 欧美黄色成人网| 日韩中文字幕精品| 国产精品爽爽爽爽爽爽在线观看| 国产成人精品999| 在线观看日韩www视频免费| 亚洲第一中文字幕| 国产91精品久久久久久久| 国产免费一区视频观看免费| 性色av一区二区三区在线观看| 精品欧美aⅴ在线网站| 91精品视频在线播放| 欧美性生交xxxxx久久久| 亚洲国产成人精品久久| 国产97在线视频| 深夜成人在线观看| 亚洲a∨日韩av高清在线观看| 91久久久精品| 久久久久久国产精品美女| 久久精品亚洲精品| 日韩电影免费在线观看| 国产精品丝袜一区二区三区| 国产精品99久久久久久久久| 亚洲桃花岛网站| 欧美一级片免费在线| 一区二区三区回区在观看免费视频| 色哟哟亚洲精品一区二区| 欧美高清视频免费观看| 久久精品成人一区二区三区| 久久国产精品免费视频| 亚洲人成网在线播放| 亚洲国产女人aaa毛片在线| 久久精品亚洲一区| 亚洲伊人久久综合| 九九视频这里只有精品| 日韩av大片在线|