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工具类封装 >>>>>>>>>>>>>>>>>> ...
随机推荐
- notepad++的环境变量
notepad++的环境变量:当前目录:$(CURRENT_DIRECTORY) cmd /k cd /d $(CURRENT_DIRECTORY)文件名:$(NAME_PART)路径名:$(CURR ...
- 05-雷海林-mysql备份原理与在TDSQL中的实践
05-雷海林-mysql备份原理与在TDSQL中的实践 下载地址: http://files.cnblogs.com/files/MYSQLZOUQI/05-%E9%9B%B7%E6%B5%B7%E6 ...
- OC 对象和匿名对象
OC 对象和匿名对象 对象和匿名对象的定义: 当new出一个对象时,如果用一个指针接收这个对象,那么这个指针通常被称为对象. 如果new出的对象,不用指针接收,那么这个对象就称为匿名对象. #impo ...
- 关于OC语法的公开和私有的讨论
关于OC语法的公开和私有的讨论 OC语法中,类的.h文件向外面暴露类的功能/方法接口,其中定义的属性/方法/协议/类别/类扩展都属于公开的,但实例变量要看限定词(@protected/@public/ ...
- UIScorlView 循环滚动
- (void) createAdScrollView { _view = [[UIView alloc] initWithFrame:CGRectMake(, , WIDTH, )]; [self. ...
- Android --ListView使用ArrayAdapter
1.继承ArrayAdapter public class TimerDataAdapter extends ArrayAdapter<TimerDataListItem> { //数据I ...
- Android --LoginActivity模板登录
Android Studio使用自带LoginActivity模板,制作登录界面 登录界面功能: 1.记住表单账户密码,并自动登录 //获得sp实例对象 sp = this.getSharedPref ...
- shell软件工具设计的原则_转
随着时间的流逝,人们开发出了一套设计与编写软件工具的原则.在本书用来解决问题的程序中,你将会看到这些原则的应用示例.好的软件工具应该具备下列特点:一次做好一件事在很多方面,这都是最重要的原则.若程序只 ...
- Unity插件研究院之ResourceChecker
这个插件是我在国外网站逛论坛发现的,试用了一下非常好用,是一个轻量级的插件就一个类.开发中尤其是和美术合作的时候,可能你会发现Project视图中有很多没有用到的资源,但是你又不敢删除,因为你不知道那 ...
- OpenGIS Simple feature access
OGIS规范定义的几何对象定义 Curve:A Curve is a 1-dimensional geometric object usually stored as a sequence of Po ...