读取.csv文件数据

CSV文件读取与数据加载到GridView
这段代码演示了如何从上传的.csv文件中读取数据并将其加载到GridView中。首先,检查文件是否存在且为.csv格式,然后使用StreamReader读取文件内容,通过分行并以逗号为分隔符分割数据,创建DataTable并填充数据,最后将DataTable绑定到GridView展示。

using System.IO;

 

private void UploadFile()
    {
        try
        {
            if (!FileUpload1.HasFile)
            {
                Response.Write("文件不存在");
                return;
            }

            string fileExtension = Path.GetExtension(FileUpload1.FileName).ToLower();//获得文件后缀

            if (!fileExtension.Equals(".csv"))
            {
                Response.Write("文件不是.csv文件");
                return;
            }

            Stream stream = FileUpload1.FileContent;
            StreamReader read = new StreamReader(stream, System.Text.Encoding.GetEncoding("gb2312"));
            System.Data.DataTable dt = new System.Data.DataTable();
            int cnt = 0;
            //循环读取流数据
            while (true)
            {
                string res = read.ReadLine();
                if (res == null) break;

                string[] strs = res.Split(',');
                if (cnt == 0)
                {
                    for (int i = 0; i < strs.Length; i++)
                        dt.Columns.Add(strs[i]);
                }
                else
                {
                    System.Data.DataRow row = dt.NewRow();
                    for (int i = 0; i < strs.Length; i++)
                        row[i] = strs[i];
                    dt.Rows.Add(row);
                }
                cnt++;
            }

            //关闭流
            if (read != null)
                read.Close();

            if (null != dt && dt.Rows.Count > 0)
            {
                GridViewDL.DataSource = dt;
                GridViewDL.DataBind();
            }
        }
        catch (Exception ex) { Response.Write("读取数据异常:" + ex.Message); }

    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值