服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - c# 对CSV文件操作(写入、读取、修改)

c# 对CSV文件操作(写入、读取、修改)

2022-10-07 15:55张中华 C#

这篇文章主要介绍了c# 如何对CSV文件操作,帮助大家更好的理解和学习C#,感兴趣的朋友可以了解下

一、DataTable数据写入CSV文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
public static void SaveCSV(DataTable dt, string fullPath)//table数据写入csv
{
  System.IO.FileInfo fi = new System.IO.FileInfo(fullPath);
  if (!fi.Directory.Exists)
  {
    fi.Directory.Create();
  }
  System.IO.FileStream fs = new System.IO.FileStream(fullPath, System.IO.FileMode.Create,
    System.IO.FileAccess.Write);
  System.IO.StreamWriter sw = new System.IO.StreamWriter(fs, System.Text.Encoding.UTF8);
  string data = "";
 
  for (int i = 0; i < dt.Columns.Count; i++)//写入列名
  {
    data += dt.Columns[i].ColumnName.ToString();
    if (i < dt.Columns.Count - 1)
    {
      data += ",";
    }
  }
  sw.WriteLine(data);
 
  for (int i = 0; i < dt.Rows.Count; i++) //写入各行数据
  {
    data = "";
    for (int j = 0; j < dt.Columns.Count; j++)
    {
      string str = dt.Rows[i][j].ToString();
      str = str.Replace("\"", "\"\"");//替换英文冒号 英文冒号需要换成两个冒号
      if (str.Contains(',') || str.Contains('"')
        || str.Contains('\r') || str.Contains('\n')) //含逗号 冒号 换行符的需要放到引号中
      {
        str = string.Format("\"{0}\"", str);
      }
 
      data += str;
      if (j < dt.Columns.Count - 1)
      {
        data += ",";
      }
    }
    sw.WriteLine(data);
  }
  sw.Close();
  fs.Close();
}

二、读取CSV文件到DataTable

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
public static DataTable OpenCSV(string filePath)//从csv读取数据返回table
{
  System.Text.Encoding encoding = GetType(filePath); //Encoding.ASCII;//
  DataTable dt = new DataTable();
  System.IO.FileStream fs = new System.IO.FileStream(filePath, System.IO.FileMode.Open,
    System.IO.FileAccess.Read);
 
  System.IO.StreamReader sr = new System.IO.StreamReader(fs, encoding);
 
  //记录每次读取的一行记录
  string strLine = "";
  //记录每行记录中的各字段内容
  string[] aryLine = null;
  string[] tableHead = null;
  //标示列数
  int columnCount = 0;
  //标示是否是读取的第一行
  bool IsFirst = true;
  //逐行读取CSV中的数据
  while ((strLine = sr.ReadLine()) != null)
  {
    if (IsFirst == true)
    {
      tableHead = strLine.Split(',');
      IsFirst = false;
      columnCount = tableHead.Length;
      //创建列
      for (int i = 0; i < columnCount; i++)
      {
        DataColumn dc = new DataColumn(tableHead[i]);
        dt.Columns.Add(dc);
      }
    }
    else
    {
      aryLine = strLine.Split(',');
      DataRow dr = dt.NewRow();
      for (int j = 0; j < columnCount; j++)
      {
        dr[j] = aryLine[j];
      }
      dt.Rows.Add(dr);
    }
  }
  if (aryLine != null && aryLine.Length > 0)
  {
    dt.DefaultView.Sort = tableHead[0] + " " + "asc";
  }
 
  sr.Close();
  fs.Close();
  return dt;
}
/// 给定文件的路径,读取文件的二进制数据,判断文件的编码类型
/// <param name="FILE_NAME">文件路径</param>
/// <returns>文件的编码类型</returns>
 
public static System.Text.Encoding GetType(string FILE_NAME)
{
  System.IO.FileStream fs = new System.IO.FileStream(FILE_NAME, System.IO.FileMode.Open,
    System.IO.FileAccess.Read);
  System.Text.Encoding r = GetType(fs);
  fs.Close();
  return r;
}
 
/// 通过给定的文件流,判断文件的编码类型
/// <param name="fs">文件流</param>
/// <returns>文件的编码类型</returns>
public static System.Text.Encoding GetType(System.IO.FileStream fs)
{
  byte[] Unicode = new byte[] { 0xFF, 0xFE, 0x41 };
  byte[] UnicodeBIG = new byte[] { 0xFE, 0xFF, 0x00 };
  byte[] UTF8 = new byte[] { 0xEF, 0xBB, 0xBF }; //带BOM
  System.Text.Encoding reVal = System.Text.Encoding.Default;
 
  System.IO.BinaryReader r = new System.IO.BinaryReader(fs, System.Text.Encoding.Default);
  int i;
  int.TryParse(fs.Length.ToString(), out i);
  byte[] ss = r.ReadBytes(i);
  if (IsUTF8Bytes(ss) || (ss[0] == 0xEF && ss[1] == 0xBB && ss[2] == 0xBF))
  {
    reVal = System.Text.Encoding.UTF8;
  }
  else if (ss[0] == 0xFE && ss[1] == 0xFF && ss[2] == 0x00)
  {
    reVal = System.Text.Encoding.BigEndianUnicode;
  }
  else if (ss[0] == 0xFF && ss[1] == 0xFE && ss[2] == 0x41)
  {
    reVal = System.Text.Encoding.Unicode;
  }
  r.Close();
  return reVal;
}
 
/// 判断是否是不带 BOM 的 UTF8 格式
/// <param name="data"></param>
/// <returns></returns>
private static bool IsUTF8Bytes(byte[] data)
{
  int charByteCounter = 1;  //计算当前正分析的字符应还有的字节数
  byte curByte; //当前分析的字节.
  for (int i = 0; i < data.Length; i++)
  {
    curByte = data[i];
    if (charByteCounter == 1)
    {
      if (curByte >= 0x80)
      {
        //判断当前
        while (((curByte <<= 1) & 0x80) != 0)
        {
          charByteCounter++;
        }
        //标记位首位若为非0 则至少以2个1开始 如:110XXXXX...........1111110X 
        if (charByteCounter == 1 || charByteCounter > 6)
        {
          return false;
        }
      }
    }
    else
    {
      //若是UTF-8 此时第一位必须为1
      if ((curByte & 0xC0) != 0x80)
      {
        return false;
      }
      charByteCounter--;
    }
  }
  if (charByteCounter > 1)
  {
    throw new Exception("非预期的byte格式");
  }
  return true;
}

三、修改文件名称

我们需要保存历史数据 或者实时的知道那个文件被修改 可以通过改变文件的名称 如加上当天的日期等等。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public static bool ChangeFileName(string OldPath, string NewPath)
{
  bool re = false;
  try
  {
    if (File.Exists(OldPath))
    {
      File.Move(OldPath, NewPath);
      re = true;
    }
  }
  catch
  {
    re = false;
  }
  return re;
}

四、CSV文件的数据写入

直接在网页表单提交数据保存在csv文件中 直接写入文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public static bool SaveCSV(string fullPath,string Data)
{
  bool re = true;
  try
  {
    FileStream FileStream = new FileStream(fullPath, FileMode.Append);
    StreamWriter sw = new StreamWriter(FileStream, System.Text.Encoding.UTF8);
    sw.WriteLine(Data);
    //清空缓冲区
    sw.Flush();
    //关闭流
    sw.Close();
    FileStream.Close();
  }
  catch
  {
    re = false;
  }
  return re;
}

以上就是c# 对CSV文件操作(写入、读取、修改)的详细内容,更多关于C# csv文件的资料请关注服务器之家其它相关文章!

原文链接:https://www.jianshu.com/p/6d1f4d3e0f75

延伸 · 阅读

精彩推荐
  • C#C#单例类的实现方法

    C#单例类的实现方法

    这篇文章主要介绍了C#单例类的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小...

    zhouzl''s blog8192022-07-27
  • C#深入理解C#中的Delegate

    深入理解C#中的Delegate

    委托是一种安全地封装方法的类型,它与 C 和 C++ 中的函数指针类似。与 C 中的函数指针不同,委托是面向对象的、类型安全的和保险的。委托的类型由委...

    ShirlySaku6562021-12-01
  • C#C#编写控制台程序纸牌游戏

    C#编写控制台程序纸牌游戏

    这篇文章主要为大家详细介绍了C#编写控制台程序纸牌游戏,适合C#初学者,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    qq_241116319182022-08-03
  • C#利用WCF双工模式实现即时通讯

    利用WCF双工模式实现即时通讯

    这篇文章主要介绍了利用WCF双工模式实现即时通讯的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    会长4142021-12-07
  • C#C#编程获取IP地址的方法示例

    C#编程获取IP地址的方法示例

    这篇文章主要介绍了C#编程获取IP地址的方法,结合实例形式分析了C#获取客户端IP地址的具体实现技巧,需要的朋友可以参考下...

    pan_junbiao3752021-12-21
  • C#C#数据结构之堆栈(Stack)实例详解

    C#数据结构之堆栈(Stack)实例详解

    这篇文章主要介绍了C#数据结构之堆栈(Stack),结合实例形式较为详细的分析了堆栈的原理与C#实现堆栈功能的相关技巧,具有一定参考借鉴价值,需要的朋友可...

    Jimmy.Yang10132021-11-04
  • C#C#实现发送手机验证码功能

    C#实现发送手机验证码功能

    之前基于c#实现手机发送验证码功能很复杂,真正做起来也就那回事,不过就是一个post请求就可以实现的东西,今天小编把思路分享到脚本之家平台,供大...

    Larry_TH9102022-01-11
  • C#Visual Studio 2019配置vue项目的图文教程详解

    Visual Studio 2019配置vue项目的图文教程详解

    这篇文章主要介绍了Visual Studio 2019配置vue项目的教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作,具有一定的参考借鉴价值...

    夏子曦8552022-08-29