C# Datatable匯出CSV演算法,c#datatable匯出csv

來源:互聯網
上載者:User

C# Datatable匯出CSV演算法,c#datatable匯出csv
/// <summary>
        /// 匯出資料到CSV檔案
        /// </summary>
        /// <param name="dtExportTable">需要匯出的datatable</param>
        /// <param name="dicColumnsInfo">匯出的列字典,key datable中的列,value需要匯出的列名稱</param>
        /// <param name="FilePath">匯出的檔案路徑</param>
        public static void ExportCSV(DataTable dtExportTable, Dictionary<string, string> dicColumnsInfo,string FilePath)
        {
            List<string> notExist=new List<string>();
            if(dtExportTable!=null&&dicColumnsInfo!=null)
            {
                foreach(string key in dicColumnsInfo.Keys)
                {
                    if(!dtExportTable.Columns.Contains(key))
                    {
                        notExist.Add(key);
                    }
                }
            }
            foreach(string key in notExist)
            {
                dicColumnsInfo.Remove(key);
            }


            for(int i=dtExportTable.Columns.Count-1;i>=0;i--)
            {
                string colName=dtExportTable.Columns[i].ColumnName;
                if(!dicColumnsInfo.ContainsKey(colName))
                {
                    dtExportTable.Columns.RemoveAt(i);
                }
            }


            if (dtExportTable == null || dtExportTable.Columns.Count <= 0 || dtExportTable.Rows.Count <= 0 || dicColumnsInfo == null || dicColumnsInfo.Count <= 0 || string.IsNullOrEmpty(FilePath))
                throw new Exception("匯出條件不滿足!");


            StringBuilder sbResult=new StringBuilder();
            int ColCount=dtExportTable.Columns.Count;
            string Header=string.Empty;
            for(int i=0;i<ColCount;i++)
            {
                if(String.IsNullOrEmpty(Header))
                {
                    Header = dicColumnsInfo[dtExportTable.Columns[i].ColumnName];
                }
                else
                {
                    Header += "," + dicColumnsInfo[dtExportTable.Columns[i].ColumnName];
                }
            }


            sbResult.AppendLine(Header);//添加表頭


            foreach(DataRow dr in dtExportTable.Rows)
            {
                string rowstring=string.Empty;
                for(int i=0;i<ColCount;i++)
                {
                    if(String.IsNullOrEmpty(rowstring))
                    {
                        rowstring=dr[i].ToString();
                    }
                    else
                    {
                        rowstring+=","+dr[i].ToString();
                    }
                }
                sbResult.AppendLine(rowstring); //添加行
            }


            File.WriteAllText(FilePath,sbResult.ToString());
        }

相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。