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

首頁 > 編程 > C# > 正文

OpenXml讀寫Excel實例代碼

2020-01-24 03:02:28
字體:
來源:轉載
供稿:網友

新版本的xlsx是使用新的存儲格式,貌似是處理過的XML。

對于OpenXML我網上搜了一下,很多人沒有介紹。所以我就這里推薦下,相信會成為信息系統開發的必備。

先寫出個例子,會發現如此的簡介:

復制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Text;
using XFormular.config;
using System.IO;
using com.xtar.amfx;
using System.Runtime.Serialization.Formatters.Binary;
using System.Data;

namespace XFormular.test
{
    class Class1
    {
        public void test()
        {
            DataTable table = new DataTable("1");
            table.Columns.Add("2");
            for (int i = 0; i < 10; i++)
            {
                DataRow row = table.NewRow();
                row[0] = i;
                table.Rows.Add(row);
            }

            List<DataTable> lsit = new List<DataTable>();
            lsit.Add(table);

            OpenXmlSDKExporter.Export(AppDomain.CurrentDomain.BaseDirectory + "http://excel.xlsx", lsit);
        }
    }
}

寫出代碼

復制代碼 代碼如下:

using System;
using System.IO;
using System.Windows.Forms;
using DocumentFormat.OpenXml;
using DocumentFormat.OpenXml.Packaging;
using DocumentFormat.OpenXml.Spreadsheet;
using DocumentFormat.OpenXml.Extensions;
using System.Collections.Generic;
using System.Data;
using System.Text.RegularExpressions;

namespace XFormular
{
    class OpenXmlSDKExporter
    {
        private static string[] Level = {"A", "B", "C", "D", "E", "F", "G",
    "H", "I", "G", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T",
    "U", "V", "W", "X", "Y", "Z" };

        public static List<DataTable> Import(string path)
        {
            List<DataTable> tables = new List<DataTable>();

            if (path.EndsWith(ExcelHelper.POSTFIX_SVN))
                return tables;

            using (MemoryStream stream = SpreadsheetReader.StreamFromFile(path))
            {
                using (SpreadsheetDocument doc = SpreadsheetDocument.Open(stream, true))
                {
                    foreach (Sheet sheet in doc.WorkbookPart.Workbook.Descendants<Sheet>())
                    {
                        DataTable table = new DataTable(sheet.Name.Value);

                        WorksheetPart worksheet = (WorksheetPart)doc.WorkbookPart.GetPartById(sheet.Id);

                        List<string> columnsNames = new List<string>();

                        foreach (Row row in worksheet.Worksheet.Descendants<Row>())
                        {
                            foreach (Cell cell in row)
                            {
                                string columnName = Regex.Match(cell.CellReference.Value, "[a-zA-Z]+").Value;

                                if (!columnsNames.Contains(columnName))
                                {
                                    columnsNames.Add(columnName);
                                }

                            }
                        }

                        columnsNames.Sort(CompareColumn);

                        foreach (string columnName in columnsNames)
                        {
                            table.Columns.Add(columnName);
                        }

                        foreach (Row row in worksheet.Worksheet.Descendants<Row>())
                        {
                            DataRow tableRow = table.NewRow();
                            table.Rows.Add(tableRow);

                            foreach (Cell cell in row)
                            {
                                string columnName = Regex.Match(cell.CellReference.Value, "[a-zA-Z]+").Value;
                                tableRow[columnName] = GetValue(cell, doc.WorkbookPart.SharedStringTablePart);
                            }
                        }

                        if (table.Rows.Count <= 0)
                            continue;
                        if (table.Columns.Count <= 0)
                            continue;

                        tables.Add(table);
                    }
                }
            }

            return tables;
        }

        public static String GetValue(Cell cell, SharedStringTablePart stringTablePart)
        {

            if (cell.ChildElements.Count == 0)

                return null;

            //get cell value

            String value = cell.CellValue.InnerText;

            //Look up real value from shared string table

            if ((cell.DataType != null) && (cell.DataType == CellValues.SharedString))

                value = stringTablePart.SharedStringTable

                .ChildElements[Int32.Parse(value)]

                .InnerText;

            return value;

        }


        public static void Export(string path, List<DataTable> tables)
        {
            using (MemoryStream stream = SpreadsheetReader.Create())
            {
                using (SpreadsheetDocument doc = SpreadsheetDocument.Open(stream, true))
                {
                    SpreadsheetWriter.RemoveWorksheet(doc, "Sheet1");
                    SpreadsheetWriter.RemoveWorksheet(doc, "Sheet2");
                    SpreadsheetWriter.RemoveWorksheet(doc, "Sheet3");

                    foreach (DataTable table in tables)
                    {
                        WorksheetPart sheet = SpreadsheetWriter.InsertWorksheet(doc, table.TableName);
                        WorksheetWriter writer = new WorksheetWriter(doc, sheet);

                        SpreadsheetStyle style = SpreadsheetStyle.GetDefault(doc);

                        foreach (DataRow row in table.Rows)
                        {
                            for (int i = 0; i < table.Columns.Count; i++)
                            {
                                string columnName = SpreadsheetReader.GetColumnName("A", i);
                                string location = columnName + (table.Rows.IndexOf(row) + 1);
                                writer.PasteText(location, row[i].ToString(), style);
                            }
                        }

                        writer.Save();
                    }
                    SpreadsheetWriter.StreamToFile(path, stream);//保存到文件中
                }
            }
        }

        private static int CompareColumn(string x, string y)
        {
            int xIndex = Letter_to_num(x);
            int yIndex = Letter_to_num(y);
            return xIndex.CompareTo(yIndex);
        }

        /// <summary>
        /// 數字26進制,轉換成字母,用遞歸算法
        /// </summary>
        /// <param name="value"></param>
        /// <returns></returns>
        private static string Num_to_letter(int value)
        {
            //此處判斷輸入的是否是正確的數字,略(正在表達式判斷)
            int remainder = value % 26;
            //remainder = (remainder == 0) ? 26 : remainder;
            int front = (value - remainder) / 26;
            if (front < 26)
            {
                return Level[front - 1] + Level[remainder];
            }
            else
            {
                return Num_to_letter(front) + Level[remainder];
            }
            //return "";
        }

        /// <summary>
        /// 26進制字母轉換成數字
        /// </summary>
        /// <param name="letter"></param>
        /// <returns></returns>
        private static int Letter_to_num(string str)
        {
            //此處判斷是否是由A-Z字母組成的字符串,略(正在表達式片段)
            char[] letter = str.ToCharArray(); //拆分字符串
            int reNum = 0;
            int power = 1; //用于次方算值
            int times = 1;  //最高位需要加1
            int num = letter.Length;//得到字符串個數
            //得到最后一個字母的尾數值
            reNum += Char_num(letter[num - 1]);
            //得到除最后一個字母的所以值,多于兩位才執行這個函數
            if (num >= 2)
            {
                for (int i = num - 1; i > 0; i--)
                {
                    power = 1;//致1,用于下一次循環使用次方計算
                    for (int j = 0; j < i; j++)           //冪,j次方,應該有函數
                    {
                        power *= 26;
                    }
                    reNum += (power * (Char_num(letter[num - i - 1]) + times));  //最高位需要加1,中間位數不需要加一
                    times = 0;
                }
            }
            //Console.WriteLine(letter.Length);
            return reNum;
        }

        /// <summary>
        /// 輸入字符得到相應的數字,這是最笨的方法,還可用ASIICK編碼;
        /// </summary>
        /// <param name="ch"></param>
        /// <returns></returns>
        private static int Char_num(char ch)
        {
            switch (ch)
            {
                case 'A':
                    return 0;
                case 'B':
                    return 1;
                case 'C':
                    return 2;
                case 'D':
                    return 3;
                case 'E':
                    return 4;
                case 'F':
                    return 5;
                case 'G':
                    return 6;
                case 'H':
                    return 7;
                case 'I':
                    return 8;
                case 'J':
                    return 9;
                case 'K':
                    return 10;
                case 'L':
                    return 11;
                case 'M':
                    return 12;
                case 'N':
                    return 13;
                case 'O':
                    return 14;
                case 'P':
                    return 15;
                case 'Q':
                    return 16;
                case 'R':
                    return 17;
                case 'S':
                    return 18;
                case 'T':
                    return 19;
                case 'U':
                    return 20;
                case 'V':
                    return 21;
                case 'W':
                    return 22;
                case 'X':
                    return 23;
                case 'Y':
                    return 24;
                case 'Z':
                    return 25;
            }
            return -1;
        }
    }
}

復制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.OleDb;

namespace xtar_biz_codegen
{
    class ExcelHelper
    {
        public static string POSTFIX_97 = "XLS";

        public static string POSTFIX_03 = "XLSX";
    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久av网站| 日韩av在线精品| 亚洲全黄一级网站| 欧美日韩国产精品专区| 亚洲的天堂在线中文字幕| 国产在线一区二区三区| 亚洲欧美日韩中文在线制服| 欧美裸体xxxx极品少妇| 欧美放荡办公室videos4k| 日韩亚洲国产中文字幕| 日韩欧美极品在线观看| 中文字幕亚洲图片| 亚洲国产精彩中文乱码av| 精品亚洲va在线va天堂资源站| 欧美性猛交丰臀xxxxx网站| 一区二区三区视频免费在线观看| 91精品久久久久久久久久久| 97视频色精品| 欧美激情视频播放| 日韩视频免费中文字幕| 久久久亚洲国产天美传媒修理工| 国产精品久久久久久久久久新婚| 亚洲男人的天堂在线播放| 97精品一区二区视频在线观看| 亚洲精品狠狠操| 国产精品精品国产| 亚洲视频综合网| 人人爽久久涩噜噜噜网站| 伊人久久精品视频| 免费av在线一区| 亚洲专区在线视频| 国产精品欧美久久久| 国产精品久久久久久亚洲影视| 欧美一级淫片丝袜脚交| 国产综合福利在线| 精品国产乱码久久久久酒店| 久久久久久久久久久久av| 97在线精品视频| 亚洲激情在线视频| 国产国语刺激对白av不卡| 在线观看成人黄色| 日韩在线激情视频| 欧美资源在线观看| 日韩精品免费综合视频在线播放| 国产精品丝袜白浆摸在线| 精品国产一区二区三区久久狼黑人| 国产精品视频一| 国产一区二区三区日韩欧美| 日韩毛片在线看| 欧美日韩不卡合集视频| 国产亚洲精品久久久| 欧美疯狂做受xxxx高潮| 日韩av在线播放资源| 国内精品久久久久影院 日本资源| 久久久久亚洲精品国产| 国产综合久久久久久| 欧美电影在线观看网站| 欧美激情一级欧美精品| 精品久久久在线观看| 精品久久久国产精品999| 午夜精品美女自拍福到在线| 久久99久久亚洲国产| 亚洲国产精品系列| 亚洲香蕉伊综合在人在线视看| 亚洲精品网站在线播放gif| 日韩欧美一区视频| 日韩最新中文字幕电影免费看| 国产999精品久久久| 日韩久久免费视频| 国产精品久久久久久久久久久新郎| 大伊人狠狠躁夜夜躁av一区| 久久影院在线观看| 久久91亚洲精品中文字幕奶水| 中文字幕亚洲综合久久筱田步美| 欧美中文字幕第一页| 国内精品久久久久| 国产精品第一第二| 精品偷拍各种wc美女嘘嘘| 国产精品久久77777| 精品久久久久久电影| 亚洲精品影视在线观看| 2018国产精品视频| 精品国产鲁一鲁一区二区张丽| 国产精品福利片| 超碰97人人做人人爱少妇| 91av在线视频观看| 秋霞成人午夜鲁丝一区二区三区| 亚洲精品视频免费在线观看| 神马国产精品影院av| 国产在线观看91精品一区| 91网在线免费观看| 日韩中文在线不卡| 91精品国产综合久久久久久久久| 国产精品久久久久久久av大片| 亚洲欧美色图片| 久久天天躁狠狠躁夜夜躁| 亚洲国产精品视频在线观看| 亚州欧美日韩中文视频| 国产99久久精品一区二区 夜夜躁日日躁| xxxxx91麻豆| 久久久久久国产精品| 亚洲美女av电影| 91日本在线观看| 91av在线国产| 欧美激情一二区| 性色av一区二区三区红粉影视| 欧美大片网站在线观看| 欧美一级片一区| 久久久久久久国产精品| 欧美—级a级欧美特级ar全黄| 欧美日韩免费在线观看| 26uuu另类亚洲欧美日本一| 亚洲另类欧美自拍| 亚洲国产毛片完整版| 精品日韩视频在线观看| 亚洲午夜未删减在线观看| 色综合久久久888| 欧美电影在线观看完整版| 日韩一级裸体免费视频| 综合国产在线观看| 亚洲一区二区三区四区视频| 91精品中文在线| 国产亚洲激情视频在线| 欧美激情视频一区二区三区不卡| 97久久伊人激情网| 久久亚洲精品一区| 日韩欧美成人网| 国产精品视频精品视频| 久久精品国产91精品亚洲| 91久久久久久国产精品| 欧美精品久久久久久久久| 久久久最新网址| 精品久久久久久电影| 97视频人免费观看| 欧美日韩在线免费| 国产精品观看在线亚洲人成网| 中文字幕精品影院| 亚洲欧美制服综合另类| 欧美电影在线观看| 国产午夜精品全部视频在线播放| 日韩天堂在线视频| 亚洲天堂av电影| 中文字幕自拍vr一区二区三区| 日本国产精品视频| 2019国产精品自在线拍国产不卡| 欧美日韩亚洲网| 日韩资源在线观看| 91中文字幕在线| 一区二区三区精品99久久| 国产成人精品电影久久久| 麻豆乱码国产一区二区三区| 午夜精品一区二区三区在线视频| 日韩精品丝袜在线| 精品毛片网大全| 9.1国产丝袜在线观看| 丰满岳妇乱一区二区三区| 久久久久国产精品一区| 精品福利一区二区| 欧美一区二区三区……| 精品日韩视频在线观看| 日韩高清电影免费观看完整版| 欧美黑人性生活视频| 国产欧美韩国高清| 亚洲va码欧洲m码|