C#win form解决导入CSV文件数据缺失问题

winform CSV文件入库数据缺失

public string TransferCSVData(string csvFile, string tablename, string connectionString)
        {
   
            try
            {
   
                DataTable dataTable = new DataTable();
                string[] columnNames = File.ReadLines(csvFile, Encoding.GetEncoding("GBK")).First().Split(',');//设置了编码格式为GBK
                foreach (string columnName in columnNames)
                {
   
                    dataTable.Columns.Add(columnName, typeof(string));
                }
                foreach (string line in File.ReadLines(csvFile, Encoding.GetEncoding("GBK")).Skip(1))//设置了编码格式为GBK
                {
   
                    string[] values = line.Split(',');
                    DataRow dataRow = dataTable.NewRow();
                    for (int i = 0; i < values.Length; i++)
                    {
   
                        dataRow[i] = values[i];
                    }
                    dataTable.Rows.Add(dataRow);
                }

                // 下面是您给出的部分代码
                int rowsnum = dataTable.Rows.Count;
                progressBar1.Maximum = rowsnum;
                using (SqlConnection connection = new SqlConnection(connectionString))
                {
   
                    connection.Open();
                    using (SqlBulkCopy bulkCopy = new SqlBulkCopy(connection))
                    {
   
                        bulkCopy.BulkCopyTimeout = 666666666;
                        bulkCopy.SqlRowsCopied += new System.Data.SqlClient.SqlRowsCopiedEventHandler(bcp_SqlRowsCopied);
                        bulkCopy.BatchSize = 100; //每次传输的行数
                        bulkCopy.NotifyAfter = 100; //进度提示的行数
                        bulkCopy.DestinationTableName = tablename; //目标表
                        bulkCopy.WriteToServer(dataTable);
                        bulkCopy.Close(); //关闭对象
                        richTextBox1.SelectionColor = Color.Blue;
                        richTextBox1.AppendText(System.IO.Path.GetFileName(csvFile) + "导入完成!!!!\n");
                        return "TAG";
                    }
                }
            }
            catch (Exception ex)
            {
   
                // 异常处理部分
                System.Windows.Forms.MessageBox.Show(ex.Message);
                richTextBox1.SelectionColor = Color.Red;
                richTextBox1.AppendText(System.IO.Path.GetFileName(csvFile) + "导入失败!!!!" + "\n");
                richTextBox2.SelectionColor = Color.Red;
                richTextBox2.AppendText(DateTime.Now.ToString("HH:mm:ss  ") + "导入异常" + "\n");
                if (ex.Message == "与源或目标中的任意列均不匹配。")
                {
   
                    richTextBox1.AppendText("详细失败原因如下:导入的EXCEL的单元格列数比设定的列数多,请检查EXCEL的数据是否异常\n");
                }
                else richTextBox1.AppendText("详细失败原因如下:" + ex.Message + "\n");
                Application.DoEvents();
                return "";
            }
        }

        public string TransferCSVData0(string csvFile, string tablename, string connectionString)
        {
   
            try
            {
   
                DataTable dataTable = new DataTable();
                string[] columnNames = File.ReadLines(csvFile).First().Split(',');
                foreach (string columnName in columnNames)
                {
   
                    dataTable.Columns.Add(columnName, typeof(string));
                }
                foreach (string line in File.ReadLines(csvFile).Skip(1))
                {
   
                    string[] values = line.Split(',');
                    DataRow dataRow = dataTable.NewRow();
                    for (int i = 0; i < values.Length; i++)
                    {
   
                        dataRow[i] = values[i];
                    }
                    dataTable.Rows.Add(dataRow);
                }
                int rowsnum = dataTable.Rows.Count;
                progressBar1.Maximum = rowsnum;
                using (SqlConnection connection = new SqlConnection(connectionString))
                {
   
                    connection.Open();
                    using (SqlBulkCopy bulkCopy = new SqlBulkCopy(connection))
                    {
   
                        bulkCopy.BulkCopyTimeout = 666666666;
                        bulkCopy.SqlRowsCopied += new System.Data.SqlClient.SqlRowsCopiedEventHandler(bcp_SqlRowsCopied);
                        bulkCopy.BatchSize = 100; //每次传输的行数
                        bulkCopy.NotifyAfter = 100; //进度提示的行数
                        bulkCopy.DestinationTableName = tablename; //目标表
                        bulkCopy.WriteToServer(dataTable);
                        bulkCopy.Close(); //关闭对象
                        richTextBox1.SelectionColor = Color.Blue;
                        richTextBox1.AppendText(System.IO.Path.GetFileName(csvFile) + "导入完成!!!!\n");
                        return "TAG";
                    }
                }
            }
            catch (Exception ex)
            {
   
                System.Windows.Forms.MessageBox.Show(ex.Message);
                richTextBox1.SelectionColor = Color.Red;
                richTextBox1.AppendText(System.IO.Path.GetFileName(csvFile) + "导入失败!!!!" + "\n");
                richTextBox2.SelectionColor = Color.Red;
                richTextBox2.AppendText(DateTime.Now.ToString("HH:mm:ss  ") + "导入异常" + "\n");
                if (ex.Message == "与源或目标中的任意列均不匹配。")
                {
   
                    richTextBox1.AppendText("详细失败原因如下:导入的EXCEL的单元格列数比设定的列数多,请检查EXCEL的数据是否异常\n");
                }
                else richTextBox1.AppendText("详细失败原因如下:" + ex.Message + "\n");
                Application.DoEvents();
                return "";
            }
        }

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-10 13:24:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-10 13:24:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-10 13:24:02       82 阅读
  4. Python语言-面向对象

    2024-02-10 13:24:02       91 阅读

热门阅读

  1. 用python制作简单的进度条(纯代码)

    2024-02-10 13:24:02       51 阅读
  2. AI绘画的兴起与人类创造力的共生未来

    2024-02-10 13:24:02       58 阅读
  3. Vue-60、Vue技术编程式路由

    2024-02-10 13:24:02       52 阅读
  4. 最长公共上升子序列——DP

    2024-02-10 13:24:02       53 阅读
  5. 【数据结构】二叉搜索树

    2024-02-10 13:24:02       53 阅读
  6. eclipse4.28.0版本如何安装FatJar插件

    2024-02-10 13:24:02       47 阅读
  7. (已解决)什么是vue导航守卫

    2024-02-10 13:24:02       52 阅读
  8. C/C++ 关于 SHA256 的使用

    2024-02-10 13:24:02       47 阅读