EPPlus助力:优雅实现Excel数据到数据库的自动迁移之旅

这里我使用了Access数据库为例,导入EPPlus如果不会请看上一篇帖子

1.首先先设置EPPlus为非商业使用

cs 复制代码
  public Homes()
  {
      InitializeComponent();

      ExcelPackage.LicenseContext = OfficeOpenXml.LicenseContext.NonCommercial; // 设置EPPlus为非商业使用
  } 

2.Access数据库连接方法

cs 复制代码
 #region Access数据库连接
 public static DataSet Get(string sql)
 {
     OleDbConnection oleDb = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + @"\你的根目录下的库名;" + "Jet OLEDB:Database Password = 你的数据库密码");
     oleDb.Close();
     DataSet dataSet = new DataSet();
     DataTable datatable = new DataTable();
     oleDb.Open();
     OleDbDataAdapter dbDataAdapter = new OleDbDataAdapter(sql, oleDb);
     dbDataAdapter.Fill(datatable);
     dataSet.Tables.Add(datatable);
     oleDb.Close();
     return dataSet;
 }
 #endregion

3.导入方法

cs 复制代码
  public static DataTable ReadExcelFile(string filePath)
  {
      using (var package = new ExcelPackage(new FileInfo(filePath)))
      {
          ExcelWorksheet worksheet = package.Workbook.Worksheets[0];
          DataTable table = new DataTable();
          int columns = worksheet.Dimension.Columns;

          // 添加表格列
          for (int col = 1; col <= columns; col++)
          {
              table.Columns.Add(worksheet.Cells[1, col].Value.ToString());
          }

          // 添加数据行
          for (int row = 2; row <= worksheet.Dimension.Rows; row++)
          {
              DataRow dataRow = table.NewRow();
              for (int col = 1; col <= columns; col++)
              {
                  dataRow[col - 1] = worksheet.Cells[row, col].Value;
              }
              table.Rows.Add(dataRow);
          }
          return table;
      }
  }

4.使用导入方法到导入到数据库

cs 复制代码
  private void button3_Click(object sender, EventArgs e)
  {
      try
      {
          OpenFileDialog openFileDialog = new OpenFileDialog();
          openFileDialog.Filter = "Excel 文件 (*.xlsx)|*.xlsx|所有文件 (*.*)|*.*";
          openFileDialog.Title = "选择 Excel 文件";
          if (openFileDialog.ShowDialog() == DialogResult.OK)
          {
              string filePath = openFileDialog.FileName;
              // 构建 SQL 语句
              DataTable excelData = ReadExcelFile(filePath);
              foreach (DataRow row in excelData.Rows)
              {
                  //这里{row["姓名"]}是你单元格中对应的每一列的表头
                  Employee.Get($"INSERT INTO workers (Name,Age,Sex,Address,Salary,status) VALUES ('{row["姓名"]}',{row["年龄"]},'{row["性别"]}','{row["住址"]}','{row["薪资"].ToString().Replace("¥", "")}',0);");
              }
          }
          Flushed();//刷新数据
          NMessage("导入数据成功", NotificationType.Info);
      }
      catch (Exception ex)
      {
          NMessage("导入数据失败"+ex.Message, NotificationType.Error);
      }
  }
相关推荐
CHANG_THE_WORLD2 分钟前
Python 中的循环结构详解
开发语言·python·c#
ChrisitineTX27 分钟前
凌晨突发Java并发问题:synchronized锁升级导致接口超时,排查过程全记录
java·数据库·oracle
极限实验室41 分钟前
Easysearch 2.0.0 性能测试
数据库·性能优化
c#上位机1 小时前
halcon获取多个独立连通域—connection
图像处理·c#·halcon
老华带你飞1 小时前
社团管理|基于Java社团管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
shayudiandian1 小时前
用LangChain打造你自己的智能问答系统
java·数据库·langchain
马克学长2 小时前
SSM特殊教育学校学生管理系统002k1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·学生管理系统·特殊教育·ssm 框架
卿雪2 小时前
Redis 线程模型:Redis为什么这么快?Redis为什么引入多线程?
java·数据库·redis·sql·mysql·缓存·golang
梁萌2 小时前
MySQL中innerDB引擎的锁机制
数据库·mysql·索引·表锁·行锁
老华带你飞3 小时前
汽车销售|汽车报价|基于Java汽车销售系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·汽车