C#操作CSV存取类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Windows.Forms;
using System.IO;
namespace FileReadAndWrite
{
<summary>
操作CSV存取类
</summary>
public class OutForCVS
{
#region 变量
<summary>
取出配置文件中的分隔符
</summary>
private static string _splitChar = null;
<summary>
取出配置文件中的编码方式
</summary>
private static string _encodeFormat = null;
#endregion
#region 构造方法
<summary>
构造方法获取分隔符、编码方式
</summary> #endregion
#region 写CSV方法
<summary>
写入CSV
</summary>
<param name="hasHeader">列头</param>
<param name="dtOutputCSV">文件内容</param>
public void WriteCSV(bool hasHeader, DataTable dtOutputCSV)
{
Log开始
INGLog.WriteLog(INGLogLevel.Debug, INGConstants.START);
获取写入文件名称以及格式
String strFileName = DateTime.Now.ToString("YYYYMMDDhhmm");
SaveFileDialog savFileDialog = new SaveFileDialog();
savFileDialog.Reset();
savFileDialog.DefaultExt = "csv";
savFileDialog.Filter = "CSV|*.csv";
savFileDialog.ShowDialog();
strFileName = savFileDialog.FileName;
判断文件名
if (string.IsNullOrEmpty(strFileName))
{
信息提示
INGMessage.ShowMessage("M009", "WriteFileName");
}
重载方法调用,写入文件
WriteCSV(hasHeader, dtOutputCSV, strFileName+".csv");
Log结束
INGLog.WriteLog(INGLogLevel.Debug, INGConstants.END);
}
#endregion
#region 写入CSV,附带路径方法
<summary>
写入CSV,附带路径
</summary>
<param name="hasHeader">列头</param>
<param name="dtOutputCSV">文件内容</param>
<param name="strPath">指定文件路径</param>
public static void WriteCSV(bool hasHeader, DataTable dtOutputCSV, string strPath)
{
Log开始
INGLog.WriteLog(INGLogLevel.Debug, INGConstants.START);
DataTable有无判断
if (dtOutputCSV == null)
{
throw new ArgumentNullException("Argument(dtOutputCSV) is null!");
}
StringBuilder初始化
StringBuilder sb = new StringBuilder();
DataTable有无数据判断
if (hasHeader)
{
添加列头
foreach (DataColumn dc in dtOutputCSV.Columns)
{
if (dc.DataType == Type.GetType("System.String"))
{
dc.ColumnName = "'" + dc.ColumnName + "'"; //修改
}
sb.Append(dc.ColumnName).Append(_splitChar);
}
创建新行
sb.Remove(sb.Length - , );
sb.Append(Environment.NewLine);
}
路径为空或者取消保存时
if (strPath == "")
{
return;
}
添加行
foreach (DataRow dr in dtOutputCSV.Rows)
{
foreach (object rowItem in dr.ItemArray)//object rowItem
{
object itemValue = rowItem;
itemValue = "'" + itemValue + "'";
sb.Append(itemValue).Append(_splitChar);
}
创建新行
sb.Remove(sb.Length - , );
sb.Append(Environment.NewLine);
}
using (TextWriter tw = new StreamWriter(strPath, false))
{
tw.Write(sb.ToString());
INGMessage.ShowMessage("M010", "Success");
tw.Flush();
tw.Close();
}
Log结束
INGLog.WriteLog(INGLogLevel.Debug, INGConstants.END);
}
#endregion
#region 读CSV文件方法
/// <summary>
/// 读CSV文件
/// </summary>
/// <param name="hasHeader">列头</param>
/// <returns>返回信息</returns>
public static DataTable ReadCSV(bool hasHeader)
{
// Log开始
//INGLog.WriteLog(INGLogLevel.Debug, INGConstants.START);
String strFileName;
using (OpenFileDialog ofdFileDialog = new OpenFileDialog())
{
ofdFileDialog.Reset();
ofdFileDialog.DefaultExt = "csv";
ofdFileDialog.Filter = "CSV|*.csv";
ofdFileDialog.ShowDialog();
// 文件名取得
strFileName = ofdFileDialog.FileName;
}
// 文件路径取得
String strFilePath = Path.GetFileName(strFileName);
// 文件路径判断
if (string.IsNullOrEmpty(strFilePath))
{
return null;
}
// Log结束
//INGLog.WriteLog(INGLogLevel.Debug, INGConstants.END);
return ReadCSV(hasHeader, strFilePath);
}
#endregion
#region 读指定路径CSV文件方法
<summary>
读指定路径CSV文件
</summary>
<param name="hasHeader">列头</param>
<param name="strPath">指定文件路径</param>
<returns>返回信息</returns>
public static DataTable ReadCSV(bool hasHeader, string strPath)
{
// Log开始
//INGLog.WriteLog(INGLogLevel.Debug, INGConstants.START);
String FileName = Path.GetFileName(strPath);
// 文件路径判断
if (string.IsNullOrEmpty(FileName))
{
return null;
}
DataTable dt = new DataTable(FileName);
// 文本文件分析instance生成
TextFieldParser parser = new TextFieldParser(strPath, Encoding.GetEncoding(_encodeFormat));
// 指定文件形式
parser.TextFieldType = FieldType.Delimited;
// 段落分割
parser.SetDelimiters(_splitChar);
// 设置CSV行计数
int iRowCnt = ;
// 到文件最后边界
while (!parser.EndOfData)
{
// 读入一行
string[] row = parser.ReadFields();
// CSV行判断
if (iRowCnt.Equals())
{
// 判断列头有无
if (hasHeader)
{
int i = ;
// 添加列到行
foreach (string sColumn in row)
{
// DataColumn初始化
DataColumn column = new DataColumn();
column.DataType = Type.GetType("System.String");
string sColumnValue = sColumn;
sColumnValue = sColumnValue.Substring(, sColumnValue.Length - );
column.ColumnName = sColumnValue;
dt.Columns.Add(column);
}
}
}
// 数据
else //修改
{
// 行添加
int rowLength = row.Length;
DataRow dr = dt.NewRow();
for (int j = ; j < rowLength; j++)
{
string columnValue = row.GetValue(j).ToString();
columnValue = columnValue.Substring(, columnValue.Length - );
dr[j] = columnValue;
}
dt.Rows.Add(dr);
}
// CSV行计数
iRowCnt++;
}
// Log结束
INGLog.WriteLog(INGLogLevel.Debug, INGConstants.END);
return dt;
}
#endregion
public void CreateCsv(System.Data.DataTable dt, string strName)
{ 先打印标头
StringBuilder strColu = new StringBuilder();
StringBuilder strValue = new StringBuilder();
int i = ;
try
{
StreamWriter sw = new StreamWriter(new FileStream(strName + ".csv", FileMode.Create), Encoding.GetEncoding("GB2312"));
for (i = ; i <= dt.Columns.Count - ; i++)
{
strColu.Append("\"" + dt.Columns[i].ColumnName + "\"");
strColu.Append(",");
}
strColu.Remove(strColu.Length - , );//移出掉最后一个,字符
sw.WriteLine(strColu);
foreach (DataRow dr in dt.Rows)
{
strValue.Remove(, strValue.Length);//移出
for (i = ; i <= dt.Columns.Count - ; i++)
{
strValue.Append("\"" + dr[i].ToString().Replace("'", "''").Replace(",", ",") + "\"");
strValue.Append(",");
}
strValue.Remove(strValue.Length - , );//移出掉最后一个,字符
sw.WriteLine(strValue);
}
sw.Close();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
} }
}
之前所写,迁移至此
原文链接:http://user.qzone.qq.com/372806800/blog/1345305065
C#操作CSV存取类的更多相关文章
- java 操作 csv文件
CSV是逗号分隔文件(Comma Separated Values)的首字母英文缩写,是一种用来存储数据的纯文本格式,通常用于电子表格或数据库软件.在 CSV文件中,数据“栏”以逗号分隔,可允许程序通 ...
- Python 操作csv和excel表格
1. 操作csv表格 使用的库 csv 1. csv文件里读取数据 代码 1. 以列表形式打开 import csv f = open('csv_test.csv', 'r') # 打开csv文件 c ...
- python操作csv和excel文件
1.操作csv文件 1).读取文件 import csv f=open("test.csv",'r') t_text=csv.reader(f) for t,i in t_text ...
- 用javacsv API 来操作csv文件
javacsv是国外开发的一个比较好的操作csv文件的API,这里简单讲一下用法. 先下载javacsv2.0.zip的文件,解压后,把javacsv.jar 添加到项目中. 本站下载地址: htt ...
- C#操作.csv文件Demo
1.使用OleDB操作.csv文件,比较费时 public static DataTable GetDataTableFromCsv(string path,bool isFirstRowHeader ...
- 自己封装的poi操作Excel工具类
自己封装的poi操作Excel工具类 在上一篇文章<使用poi读写Excel>中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完 ...
- Redis操作Set工具类封装,Java Redis Set命令封装
Redis操作Set工具类封装,Java Redis Set命令封装 >>>>>>>>>>>>>>>>& ...
- Redis操作List工具类封装,Java Redis List命令封装
Redis操作List工具类封装,Java Redis List命令封装 >>>>>>>>>>>>>>>> ...
- Redis操作Hash工具类封装,Redis工具类封装
Redis操作Hash工具类封装,Redis工具类封装 >>>>>>>>>>>>>>>>>> ...
随机推荐
- Oracle本地网络分表模拟分区裁剪
来自讨论贴 http://www.itpub.net/thread-1877111-1-1.html 准备数据表 2014-07-20 01:38:10>create table tb_1 as ...
- JavaScript:综合案例---房贷计算器的实现
房贷计算器的实现 (可以使用的编辑器:webStrom.subLime.notePad++.editPlus) 输入数据: 平方单价 70,000.00 元/平方 B1 租金 382.50 元/平方 ...
- linux安装MySQL5.7.13(二进制|源码)
二进制和源码版本安装MySQL5.7.13,并简单介绍不同之处. 一.通用二进制部分 1.下载MySQL通用二进制软件包.[root@node1 ~]# wget http://120.52.72.2 ...
- python中几个常用的算术函数
1.lambda函数(匿名函数) lambda函数使用方式:lambda[参数1,参数2....]:表达式,列表 实例如下: lambda x : x * 2,[1,2,3,4] lambda 2.r ...
- 选择年份 php的写法要比js简洁一些
所以遇到下拉框默认选择的情况,用php写比较方便一些 <select type="text" class="form-control_2" name=&q ...
- 单臂路由+DHCP+VLAN
使用思科模拟软件Cisco Packet Tracer Student,软件功能有限,只能架设简单的网络架构,适合初学者使用.
- js实现svg图形转存为图片下载
我们知道canvas画布可以很方便的js原生支持转为图片格式并下载,但是svg矢量图形则并没有这方面原生的支持.研究过HighChart的svg图形的图片下载机制,其实现原理大体是浏览器端收集SVG代 ...
- Hadoop学习笔记: 安装配置Hadoop
安装前的一些环境配置: 1. 给用户添加sudo权限,输入su - 进入root账号,然后输入visudo,进入编辑模式,找到这一行:"root ALL=(ALL) ALL"在下面 ...
- iOS 快递查询
#import <UIKit/UIKit.h> @interface AppDelegate : UIResponder <UIApplicationDelegate> @pr ...
- GPU 优化总结
前面说了对我这一年多的工作进行一个总结,由于工作比较紧,加上本人比较懒,一直没能抽出时间来写,最近稍微闲下来了.先写一篇GPU优化的,后续的文章希望能慢慢补齐.这些基本都是我个人优化的实际经验,也参考 ...