将DataTable数据导出到Excel中

本文介绍了一种将DataTable数据转换为CSV文件的方法。该方法首先检查并创建必要的目录,然后逐行读取DataTable,并将列名及数据写入CSV文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 /// <summary>
        /// データテーブルからCSVファイルに変更する
        /// </summary>
        /// <param name="i_fileName">CSVファイル名</param>
        /// <param name="i_data">データテーブル</param>
        public static bool DataTableToCsv(string i_fileName, DataTable i_data)
        {
            StreamWriter sw = null;
            try
            {
                string dir = i_fileName.Substring(0, i_fileName.LastIndexOf("\\"));
                if (!Directory.Exists(dir))
                {
                    Directory.CreateDirectory(dir);
                }


                // CSV ファイルオープン
                System.Text.Encoding encoding = System.Text.Encoding.Default;
                sw = new StreamWriter(i_fileName, false, encoding);


                // 1 行ずつ書き込む
                for (int i = 0; i <= i_data.Rows.Count; i++)
                {
                    StringBuilder strBuilder = new StringBuilder();


                    for (int j = 0; j < i_data.Columns.Count - 1; j++)
                    {
                        if (i == 0)
                        {
                            //カラム時
                            if (string.IsNullOrEmpty(i_data.Columns[j].Caption) == false)
                            {
                                strBuilder.Append(i_data.Columns[j].Caption);
                            }
                            else
                            {
                                strBuilder.Append(i_data.Columns[j].ColumnName);
                            }
                        }
                        else
                        {
                            //データ時
                            strBuilder.Append(convCsvValue(DataUtil.CStr(i_data.Rows[i - 1][j])));
                        }




                        strBuilder.Append(",");
                    }


                    if (i == 0)
                    {
                        //カラム時
                        strBuilder.Append(i_data.Columns[i_data.Columns.Count - 1].Caption);
                    }
                    else
                    {
                        //データ時
                        strBuilder.Append(convCsvValue(DataUtil.CStr(i_data.Rows[i - 1][i_data.Columns.Count - 1])));
                    }


                    if (i != i_data.Rows.Count)
                    {
                        sw.WriteLine(strBuilder);
                    }
                    else
                    {
                        sw.Write(strBuilder);
                    }
                }
                // ファイルクローズ
                sw.Close();




                return true;


            }
            catch
            {
                //SeisanClientLogService.WriteException("CSV出力が失敗しました", ex);
                return false;
            }
            finally
            {
                if (sw != null)
                {
                    // ファイルクローズ
                    sw.Close();
                }
            }


        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值