C#读取保存csv文件

帮写了个小程序,有些小细节

1.读取(弹出对话框供选择文件)

private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                OpenFileDialog file = new OpenFileDialog();
                file.ShowDialog();
                FileStream fs = new FileStream(file.FileName, System.IO.FileMode.Open, System.IO.FileAccess.Read);
                StreamReader sr = new StreamReader(fs, System.Text.Encoding.Default);
                //记录每次读取的一行记录
                string strLine = "";
                //记录每行记录中的各字段内容
                string[] aryLine;
                //读取第一行    
                sr.ReadLine();
                strLine = strLine.Trim();
                string[] separators = { "," }; // { ",", ".", "!", "?", ";", ":", " " };
                aryLine = strLine.Split(separators, System.StringSplitOptions.RemoveEmptyEntries);
                //逐行读取CSV中的数据
                while ((strLine = sr.ReadLine()) != null)
                {
                    strLine = strLine.Trim();
                    aryLine = strLine.Split(separators, System.StringSplitOptions.RemoveEmptyEntries);

                    if (aryLine.Length > 1)
                    {
                            /
                    }

                }
                label1.Text = file.FileName;
                label1.Visible = true;
                sr.Close();
                fs.Close();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.ToString());
            }
        }

2.写入(弹出对话框供选择文件)

private void button3_Click(object sender, EventArgs e)
        {
            try
            {
                SaveFileDialog file = new SaveFileDialog();
                file.Filter = "csv文件|*.csv";
                file.InitialDirectory = "C:\\Users\\admin\\Desktop";
                file.ShowDialog();
                // 实例化流对象,以特定的编码向流中写入字符。  
                FileStream fs = new FileStream(file.FileName, System.IO.FileMode.Create, System.IO.FileAccess.Write);
                StreamWriter sw = new StreamWriter(fs, Encoding.GetEncoding("gb2312"));
                //写入首行
                string sb = "nodeID,tagid";
                sw.WriteLine(sb);

                foreach (var i in XyToNodeDict)
                {
                    /
                    foreach (var j in XyToTagDict)
                    {
                         
                    }
                    sw.WriteLine(data);
                }

                label3.Text = file.FileName;
                label3.Visible = true;
                sw.Flush();
                sw.Close();
                sw.Dispose();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.ToString());
            }
        }

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值