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

首頁 > 編程 > C# > 正文

C# 解析 Excel 并且生成 Csv 文件代碼分析

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

今天工作中遇到一個需求,就是獲取 excel 里面的內容,并且把 excel 另存為 csv,因為本人以前未接觸過,所以下面整理出來的代碼均來自網絡,具體參考鏈接已丟失,原作者保留所有權利!

例子:

復制代碼 代碼如下:

using System;
using System.Data;

namespace ExportExcelToCode
{
    class ExcelOperater
    {
        public void Operater()
        {
            // Excel 路徑
            string excelPath = "";
            // Csv 存放路徑
            string csvPath = "";

            // 獲取 Excel Sheet 名稱列表
            string[] sheetNameList = ExcelUtils.GetSheetNameList(excelPath);

            if (sheetNameList != null && sheetNameList.Length > 0)
            {
                foreach (string sheetName in sheetNameList)
                {
                    string itemName = sheetName.TrimEnd(new char[] { '$' });

                    // 解析 Excel 為 DataTable 對象
                    DataTable dataTable = ExcelUtils.ExcelToDataTable(excelPath, itemName);
                    if (dataTable != null && dataTable.Rows.Count > 0)
                    {
                        // 生成 Csv 文件
                        ExcelUtils.ExcelToCsv(excelPath, csvPath, itemName, "|#|", 0);
                    }
                }
            }
        }
    }
}

ExcelUtils.cs 文件

復制代碼 代碼如下:

using System;  
using System.Data;
using Microsoft.Office.Interop.Excel;
using Excel = Microsoft.Office.Interop.Excel;

namespace ExportExcelToCode
{
    public partial class ExcelUtils
    {
        /// <summary>
        /// 獲取 Sheet 名稱
        /// </summary>
        /// <param name="filePath"></param>
        /// <returns></returns>
        public static string[] GetSheetNameList(string filePath)
        {
            try
            {
                string connectionText = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + filePath + ";" + "Extended Properties='Excel 12.0;HDR=YES;IMEX=1';";

                System.Data.OleDb.OleDbConnection oleDbConnection = new System.Data.OleDb.OleDbConnection(connectionText);

                oleDbConnection.Open();

                System.Data.DataTable dataTable = oleDbConnection.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" }); ;

                string[] sheetNameList = new string[dataTable.Rows.Count];

                for (int index = 0; index < dataTable.Rows.Count; index++)
                {
                    sheetNameList[index] = dataTable.Rows[index][2].ToString();
                }

                oleDbConnection.Close();

                return sheetNameList;
            }
            catch (Exception ex)
            {
                return null;
            }
        }

        /// <summary>
        /// Excel 轉 DataTable
        /// </summary>
        /// <param name="filePath"></param>
        /// <param name="sheetName"></param>
        /// <returns></returns>
        public static System.Data.DataTable ExcelToDataTable(string filePath, string sheetName)
        {
            try
            {
                string connectionText = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + filePath + ";" + "Extended Properties='Excel 12.0;HDR=YES;IMEX=1';";
                string selectText = string.Format("select * from [{0}$]", sheetName);

                DataSet dataSet = new DataSet();

                System.Data.OleDb.OleDbConnection oleDbConnection = new System.Data.OleDb.OleDbConnection(connectionText);

                oleDbConnection.Open();

                System.Data.OleDb.OleDbDataAdapter oleDbDataAdapter = new System.Data.OleDb.OleDbDataAdapter(selectText, connectionText);
                oleDbDataAdapter.Fill(dataSet, sheetName);

                oleDbConnection.Close();

                return dataSet.Tables[sheetName];
            }
            catch (Exception ex)
            {
                return null;
            }
        }

        /// <summary>
        /// Excel 轉 Csv
        /// </summary>
        /// <param name="sourceExcelPathAndName"></param>
        /// <param name="targetCSVPathAndName"></param>
        /// <param name="excelSheetName"></param>
        /// <param name="columnDelimeter"></param>
        /// <param name="headerRowsToSkip"></param>
        /// <returns></returns>
        public static bool ExcelToCsv(string sourceExcelPathAndName, string targetCSVPathAndName, string excelSheetName, string columnDelimeter, int headerRowsToSkip)
        {
            Excel.Application oXL = null;
            Excel.Workbooks workbooks = null;
            Workbook mWorkBook = null;
            Sheets mWorkSheets = null;
            Worksheet mWSheet = null;

            try
            {
                oXL = new Excel.Application();
                oXL.Visible = false;
                oXL.DisplayAlerts = false;
                workbooks = oXL.Workbooks;
                mWorkBook = workbooks.Open(sourceExcelPathAndName, 0, false, 5, "", "", false, XlPlatform.xlWindows, "", true, false, 0, true, false, false);
                mWorkSheets = mWorkBook.Worksheets;
                mWSheet = (Worksheet)mWorkSheets.get_Item(excelSheetName);
                Excel.Range range = mWSheet.UsedRange;
                Excel.Range rngCurrentRow;
                for (int i = 0; i < headerRowsToSkip; i++)
                {
                    rngCurrentRow = range.get_Range("A1", Type.Missing).EntireRow;
                    rngCurrentRow.Delete(XlDeleteShiftDirection.xlShiftUp);
                }
                range.Replace("/n", " ", Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
                range.Replace(",", columnDelimeter, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);

                mWorkBook.SaveAs(targetCSVPathAndName, Excel.XlFileFormat.xlCSV,
                Type.Missing, Type.Missing, Type.Missing, Type.Missing, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlExclusive,
                Type.Missing, Type.Missing, Type.Missing,
                Type.Missing, false);
                return true;
            }
            catch (Exception ex)
            {
                return false;
            }
            finally
            {
                if (mWSheet != null) mWSheet = null;
                if (mWorkBook != null) mWorkBook.Close(Type.Missing, Type.Missing, Type.Missing);
                if (mWorkBook != null) mWorkBook = null;
                if (oXL != null) oXL.Quit();
                System.Runtime.InteropServices.Marshal.ReleaseComObject(oXL);
                if (oXL != null) oXL = null;
                GC.WaitForPendingFinalizers();
                GC.Collect();
                GC.WaitForPendingFinalizers();
                GC.Collect();
            }
        }
    }
}


需要特別指出的是:需要在項目中添加 Microsoft.Office.Interop.Excel.dll 文件,具體操作:選中引用->右鍵添加引用->瀏覽找到 Microsoft.Office.Interop.Excel,添加引用。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美第一页| 国产精品一区二区性色av| 中文字幕日韩av电影| 91精品国产91久久久久久不卡| 国产精品高清免费在线观看| 黄色精品一区二区| 久久99精品视频一区97| 日韩精品黄色网| 久久亚洲精品小早川怜子66| 成人激情视频在线观看| 麻豆国产精品va在线观看不卡| 日韩成人在线视频网站| 国产91露脸中文字幕在线| 中文字幕精品一区久久久久| 国产情人节一区| 亚洲xxx自由成熟| 欧美伦理91i| 日韩av免费观影| 久久亚洲国产成人| 国产aaa精品| 最近免费中文字幕视频2019| 97婷婷大伊香蕉精品视频| 欧美精品福利在线| 色七七影院综合| 精品中文字幕视频| 中日韩午夜理伦电影免费| 国产91精品视频在线观看| 亚洲第一精品自拍| 日韩美女在线观看| 色中色综合影院手机版在线观看| 亚洲老头老太hd| 久久久久久久成人| 欧美成人黑人xx视频免费观看| 96pao国产成视频永久免费| 亚洲xxxx18| 国外成人免费在线播放| 97香蕉超级碰碰久久免费的优势| 亚洲国产精品成人一区二区| 国产一区二区三区视频免费| 国产日韩在线亚洲字幕中文| 亚洲精品天天看| 亚洲人成绝费网站色www| 亚洲精品久久在线| 国产日韩欧美在线播放| 91成人在线视频| 亚洲欧美成人精品| 国产91在线视频| 欧美高清一级大片| 亚洲欧美国产一本综合首页| 欧美综合第一页| 国产精品久久久久久久久久99| 中文字幕欧美日韩在线| 欧美久久精品午夜青青大伊人| 日产精品99久久久久久| 91在线网站视频| 亚洲国产精品美女| 黑人巨大精品欧美一区二区免费| 欧美一区二区三区精品电影| 亚洲欧美精品一区| 中文字幕av一区二区| 97人人模人人爽人人喊中文字| 欧美大片va欧美在线播放| 亚洲综合成人婷婷小说| 日韩免费av一区二区| 亚洲视频专区在线| 久久久久999| 国产国语videosex另类| 日本最新高清不卡中文字幕| 亚洲的天堂在线中文字幕| 日本欧美国产在线| 亚洲精品日韩丝袜精品| 日日狠狠久久偷偷四色综合免费| 久久91超碰青草是什么| 久久亚洲欧美日韩精品专区| 57pao国产精品一区| 91高清在线免费观看| www.日韩av.com| 亚洲精品wwwww| 国模gogo一区二区大胆私拍| 日韩av网站在线| 久久久久久久久久久人体| 欧美日韩国产一区二区三区| 亚洲自拍小视频| 久久久国产一区二区| 亚洲国产古装精品网站| 色婷婷**av毛片一区| 国产综合福利在线| 国产日韩视频在线观看| 日韩精品视频免费| 中文字幕亚洲欧美在线| 美女久久久久久久久久久| 啊v视频在线一区二区三区| 亚洲激情电影中文字幕| 国产一区红桃视频| 亚洲风情亚aⅴ在线发布| 懂色aⅴ精品一区二区三区蜜月| 亚洲精品有码在线| 69视频在线播放| 欧美激情免费观看| 欧美激情一区二区三区高清视频| 欧美成人精品在线观看| 欧美成人性生活| 久久精品亚洲94久久精品| 91伊人影院在线播放| 91久久国产婷婷一区二区| 欧美与黑人午夜性猛交久久久| 国产精品稀缺呦系列在线| 久久久久国色av免费观看性色| 亚洲欧美999| 国产精品爽黄69| 亚洲精品国精品久久99热| 欧美成人激情视频| 黑人巨大精品欧美一区二区免费| 成人动漫网站在线观看| 国产精品久久久久久五月尺| 国产99视频精品免视看7| 欧美不卡视频一区发布| 欧美精品在线看| 欧美中文字幕在线视频| 亚洲一区av在线播放| 日韩一区二区久久久| 超碰精品一区二区三区乱码| 亚洲高清色综合| 亚洲视频电影图片偷拍一区| 91麻豆国产语对白在线观看| 欧美精品videossex性护士| 欧美理论电影网| 久久黄色av网站| 欧美日韩一区二区三区在线免费观看| 欧美日韩国产在线| 亚洲欧美精品伊人久久| 欧美精品videosex极品1| 亚洲成人免费在线视频| 国产91精品最新在线播放| 欧美成年人网站| 91精品久久久久久久久青青| 欧美在线视频免费播放| 亚洲国产欧美一区二区丝袜黑人| 97国产真实伦对白精彩视频8| 在线激情影院一区| 亚洲精品视频网上网址在线观看| 日韩电影免费观看中文字幕| 国产免费一区二区三区在线能观看| 欧美性猛交xxxx乱大交| 久久69精品久久久久久国产越南| 在线观看成人黄色| 97视频色精品| 欧美极品少妇全裸体| 欧美精品成人91久久久久久久| 成人伊人精品色xxxx视频| 国产精品美女在线| 亚洲精品中文字幕av| 91香蕉嫩草神马影院在线观看| 久久成人av网站| 国产精品99久久99久久久二8| 成人写真视频福利网| 欧美日韩国产一区二区三区| 欧美日韩国产成人在线观看| 在线观看精品国产视频| 欧美性生活大片免费观看网址| 久久精品视频va| 久久欧美在线电影| 欧美裸体男粗大视频在线观看| 亚洲自拍偷拍色图|