在C#交流群里,看到很多小伙伴在excel数据导入导出到C#界面上存在疑惑,所以今天专门做了这个主题,希望大家有所收获!

环境:win10+vs2017

界面:主要以演示为主,所以没有做优化,然后主界面上添加两个按钮,分别命名为ExportExcel和ImportExcel,添加两个dataGridView,分别是dataGridView1和dataGridView2

然后在窗体加载程序中给dataGridView1写入三行数据,代码如下:

DataTable dt = new DataTable();
            dt.Columns.Add("Name");
            dt.Columns.Add("Age");
            dt.Rows.Add("小王","15");
            dt.Rows.Add("老李","42");
            dt.Rows.Add("老张","25");
            dataGridView1.DataSource = dt;

软件运行后,点击ExportExcel,则将datagridview1的数据保存到excel中,点击ImportExcel,选择excel后读取数据到datagridview2.

注意:如果报System.InvalidOperationException:“未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序。”请检查office是否正确安装

具体步骤:

step1:引用dll,在nuget上安装Microsoft.Office.Interop.Excel

step2:code

主要由三个方法:

  1. public void ExportExcel() 实现数据导出到excel

  2. public DataSet ImportExcel(int t = 1)实现读取excel数据

  3. public void ExportCSV() 数据导出到csv

    其次

  4. 保存选项对话框  string fileName = "";                string saveFileName = "";                SaveFileDialog saveDialog = new SaveFileDialog();                saveDialog.DefaultExt = "xlsx";                saveDialog.InitialDirectory = @"C:\BMDT";                saveDialog.Filter = "Excel文件|*.xlsx";                // saveDialog.FileName = fileName;                saveDialog.FileName = "BMDT_Data_" + DateTime.Now.ToLongDateString().ToString();                saveDialog.ShowDialog();                saveFileName = saveDialog.FileName;                if (saveFileName.IndexOf(":") < 0)                {                    this.Cursor = Cursors.Default;                    return; //被点了取消                }

    完整代码如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;using System.IO;
using System.Data.SqlClient;
using Excel = Microsoft.Office.Interop.Excel;
using System.Reflection;
using System.Xml;
using System.Data.OleDb;namespace excelReadWriter
{public partial class Form1 : Form{public Form1(){InitializeComponent();}#region /* 数据导出到excel */public void ExportExcel(){try{this.Cursor = Cursors.WaitCursor;if (!Directory.Exists(@"C:\BMDT"))Directory.CreateDirectory(@"C:\BMDT");string fileName = "";string saveFileName = "";SaveFileDialog saveDialog = new SaveFileDialog();saveDialog.DefaultExt = "xlsx";saveDialog.InitialDirectory = @"C:\BMDT";saveDialog.Filter = "Excel文件|*.xlsx";// saveDialog.FileName = fileName;saveDialog.FileName = "BMDT_Data_" + DateTime.Now.ToLongDateString().ToString();saveDialog.ShowDialog();saveFileName = saveDialog.FileName;if (saveFileName.IndexOf(":") < 0){this.Cursor = Cursors.Default;return; //被点了取消}Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application();if (xlApp == null){MessageBox.Show("无法创建Excel对象,您的电脑可能未安装Excel");return;}Microsoft.Office.Interop.Excel.Workbooks workbooks = xlApp.Workbooks;Microsoft.Office.Interop.Excel.Workbook workbook = workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[1];//取得sheet1 Microsoft.Office.Interop.Excel.Range range = worksheet.Range[worksheet.Cells[4, 1], worksheet.Cells[8, 1]];//写入标题             for (int i = 0; i < dataGridView1.ColumnCount; i++){ worksheet.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText; }//写入数值for (int r = 0; r < dataGridView1.Rows.Count; r++){for (int i = 0; i < dataGridView1.ColumnCount; i++){worksheet.Cells[r + 2, i + 1] = dataGridView1.Rows[r].Cells[i].Value;if (this.dataGridView1.Rows[r].Cells[i].Style.BackColor == Color.Red){range = worksheet.Range[worksheet.Cells[r + 2, i + 1], worksheet.Cells[r + 2, i + 1]];range.Interior.ColorIndex = 10;}}System.Windows.Forms.Application.DoEvents();}worksheet.Columns.EntireColumn.AutoFit();//列宽自适应MessageBox.Show(fileName + "资料保存成功", "提示", MessageBoxButtons.OK);if (saveFileName != ""){try{workbook.Saved = true;workbook.SaveCopyAs(saveFileName);  //fileSaved = true;  }catch (Exception ex){//fileSaved = false;                      MessageBox.Show("导出文件时出错,文件可能正被打开!\n" + ex.Message);}}xlApp.Quit();GC.Collect();//强行销毁           this.Cursor = Cursors.Default;}catch(Exception e){this.Cursor = Cursors.Default;MessageBox.Show(e.ToString());}}#endregion#region /* ImportExcel(int t) */public DataSet ImportExcel(int t = 1){//打开文件string sql_select = string.Empty;OpenFileDialog file = new OpenFileDialog();file.Filter = "Excel(*.xlsx)|*.xlsx|Excel(*.xls)|*.xls|(*.csv)|*.csv";file.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);file.Multiselect = false;if (file.ShowDialog() == DialogResult.Cancel)return null;//判断文件后缀var path = file.FileName;string fileSuffix = System.IO.Path.GetExtension(path);if (string.IsNullOrEmpty(fileSuffix))return null;using (DataSet ds = new DataSet()){//判断Excel文件是2003版本还是2007版本string connString = "";if (fileSuffix == ".xls")connString = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + path + ";" + ";Extended Properties=\"Excel 8.0;HDR=YES;IMEX=1\"";elseconnString = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + path + ";" + ";Extended Properties=\"Excel 12.0;HDR=YES;IMEX=1\"";//读取文件if (t == 1)sql_select = " SELECT ID,CREATETIME,REASONCODE1,PROCESSID FROM [Sheet1$] ";else if (t == 2)sql_select = " SELECT PANELID,EVENTTIME,DESCRIPTION,PROCESSID FROM [Grid$] ";else if (t == 3)sql_select = " SELECT Operation,Lot_ID,EQP_ID,Event_Time FROM [报表1$] ";using (OleDbConnection conn = new OleDbConnection(connString))using (OleDbDataAdapter cmd = new OleDbDataAdapter(sql_select, conn)){conn.Open();cmd.Fill(ds);}if (ds == null || ds.Tables.Count <= 0) return null;return ds;}}#endregionprivate void button1_Click(object sender, EventArgs e){ExportExcel();}private void Form1_Load(object sender, EventArgs e){DataTable dt = new DataTable();dt.Columns.Add("Name");dt.Columns.Add("Age");dt.Rows.Add("小王","15");dt.Rows.Add("老李","42");dt.Rows.Add("老张","25");dataGridView1.DataSource = dt;}private void button2_Click(object sender, EventArgs e){DataSet ds = new DataSet();ds = ImportExcel();dataGridView2.DataSource = ds.Tables[0];// ExportCSV();}#region /* 数据导出到CSV */public void ExportCSV(){if (dataGridView1.Rows.Count == 0){MessageBox.Show("没有数据可导出!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);return;}SaveFileDialog saveFileDialog = new SaveFileDialog();saveFileDialog.Filter = "CSV files (*.csv)|*.csv";saveFileDialog.FilterIndex = 0;saveFileDialog.RestoreDirectory = true;saveFileDialog.CreatePrompt = true;saveFileDialog.FileName = null;saveFileDialog.Title = "保存";if (saveFileDialog.ShowDialog() == DialogResult.OK){Stream stream = saveFileDialog.OpenFile();StreamWriter sw = new StreamWriter(stream, System.Text.Encoding.GetEncoding(-0));string strLine = "";try{for (int i = 0; i < dataGridView1.ColumnCount; i++){if (i > 0)strLine += ",";strLine += dataGridView1.Columns[i].HeaderText;}strLine.Remove(strLine.Length - 1);sw.WriteLine(strLine);strLine = "";//表的内容for (int j = 0; j < dataGridView1.Rows.Count; j++){strLine = "";int colCount = dataGridView1.Columns.Count;for (int k = 0; k < colCount; k++){if (k > 0 && k < colCount)strLine += ",";if (dataGridView1.Rows[j].Cells[k].Value == null)strLine += "";else{string cell = dataGridView1.Rows[j].Cells[k].Value.ToString().Trim();//防止里面含有特殊符号cell = cell.Replace("\"", "\"\"");cell = "\"" + cell + "\"";strLine += cell;}}sw.WriteLine(strLine);}sw.Close();stream.Close();MessageBox.Show("数据被导出到:" + saveFileDialog.FileName.ToString(), "导出完毕", MessageBoxButtons.OK, MessageBoxIcon.Information);}catch (Exception ex){MessageBox.Show(ex.Message, "导出错误", MessageBoxButtons.OK, MessageBoxIcon.Information);}}}#endregion}
}

运行效果:

如果你想把数据导入csv文件,则可以用以下方法:

#region /* 数据导出到CSV */public void ExportCSV(){if (dataGridView1.Rows.Count == 0){MessageBox.Show("没有数据可导出!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);return;}SaveFileDialog saveFileDialog = new SaveFileDialog();saveFileDialog.Filter = "CSV files (*.csv)|*.csv";saveFileDialog.FilterIndex = 0;saveFileDialog.RestoreDirectory = true;saveFileDialog.CreatePrompt = true;saveFileDialog.FileName = null;saveFileDialog.Title = "保存";if (saveFileDialog.ShowDialog() == DialogResult.OK){Stream stream = saveFileDialog.OpenFile();StreamWriter sw = new StreamWriter(stream, System.Text.Encoding.GetEncoding(-0));string strLine = "";try{for (int i = 0; i < dataGridView1.ColumnCount; i++){if (i > 0)strLine += ",";strLine += dataGridView1.Columns[i].HeaderText;}strLine.Remove(strLine.Length - 1);sw.WriteLine(strLine);strLine = "";//表的内容for (int j = 0; j < dataGridView1.Rows.Count; j++){strLine = "";int colCount = dataGridView1.Columns.Count;for (int k = 0; k < colCount; k++){if (k > 0 && k < colCount)strLine += ",";if (dataGridView1.Rows[j].Cells[k].Value == null)strLine += "";else{string cell = dataGridView1.Rows[j].Cells[k].Value.ToString().Trim();//防止里面含有特殊符号cell = cell.Replace("\"", "\"\"");cell = "\"" + cell + "\"";strLine += cell;}}sw.WriteLine(strLine);}sw.Close();stream.Close();MessageBox.Show("数据被导出到:" + saveFileDialog.FileName.ToString(), "导出完毕", MessageBoxButtons.OK, MessageBoxIcon.Information);}catch (Exception ex){MessageBox.Show(ex.Message, "导出错误", MessageBoxButtons.OK, MessageBoxIcon.Information);}}}#endregion

----------------------------------------------------------

如果觉得有用,麻烦点击 在看,让更多志同道合的伙伴加入我们的交流群,一起共同进步!

C# excel文件导入导出相关推荐

  1. EasyPoi实现excel文件导入导出

    EasyPoi学习实践 1 简介 easypoi功能如同名字easy,主打的功能就是容易,让一个没见接触过poi的人员 就可以方便的写出Excel导出,Excel模板导出,Excel导入,Word模板 ...

  2. EasyExcel实现Excel文件导入导出

    1 EasyExcel简介 EasyExcel是一个基于Java的简单.省内存的读写Excel的开源项目.在尽可能节约内存的情况下支持读写百M的Excel. github地址: https://git ...

  3. Excel文件导入导出操作

    > 注意!注意!!注意!!! 文末有惊喜彩蛋,请注意查收! 日常开发工作中对于文件的相关操作大家多少都会涉及:上传解析.数据导出等.此篇内容主要分享一下工作中常用的Excel文件的解析和导出工作 ...

  4. EasyExcel实现Excel文件导入导出功能

    一.EasyExcel简介 Java领域解析.生成Excel比较有名的框架有Apache poi.jxl等.但他们都存在一个严重的问题就是非常的耗内存.如果你的系统并发量不大的话可能还行,但是一旦并发 ...

  5. vue实现Excel文件导入导出

    <template><div class="index" v-loading.fullscreen.lock="fullscreenLoading&qu ...

  6. postman测试Excel文件导入导出功能

    导入Excel核心代码 @ApiOperation("导入Excel")@PostMapping("/importExcel")public ActionRes ...

  7. php laravel导入excel,Laravel 5使用Laravel Excel实现Excel/CSV文件导入导出的功能详解

    @H_404_0@ 1.简介 @H_404_0@本文主要给大家介绍了关于Laravel 5用Laravel Excel实现Excel/CSV文件导入导出的相关内容,下面话不多说了,来一起看看详细的介绍 ...

  8. Laravel Excel实现Excel/CSV文件导入导出的功能详解(合并单元格,设置单元格样式)

    Laravel Excel实现Excel/CSV文件导入导出(合并单元格,设置单元格样式) 这篇文章主要给大家介绍了关于在Laravel中如何使用Laravel Excel实现Excel/CSV文件导 ...

  9. react-前端excel 文件/PDF文件 导入 --导出、照片上传、mp4格式视频下载

    需要了解,new FormData() --上传时,将内容转为文件流 FormData提供一种表示表单数据的键值对的构造方式,实现表单数据的序列化,从而减少表单元素的拼接,提高工作效率 new Fil ...

最新文章

  1. 二叉树-对称二叉树(递归法)
  2. Android开发举步维艰,上弘法寺七七四十九天取得“真经”!
  3. __str__的用法
  4. 《四世同堂》金句摘抄(十六)
  5. 读完《云原生架构白皮书》,我们来谈谈开放应用模型(OAM)
  6. Pandas知识点-比较操作
  7. SQLyog创建表示的bug
  8. Spring Boot –无法确定数据库类型NONE的嵌入式数据库驱动程序类
  9. java servlet深入理解_深入理解 Java Servlet
  10. 再问:支付宝即时到账集成接口!
  11. IsHitTestVisible=False 的功能
  12. python turtle菜鸟教程_Python 基础教程
  13. Win10系统隐藏磁盘
  14. JAVA基本IO操作
  15. 工作记录软件app,可以写工作记录的便签软件
  16. 阿里大文娱管理层调整?回应:分工去年宣布 不是新闻
  17. matlab神经网络工具箱实现两个输入的BP神经网络
  18. 弘辽科技:限制店铺流量上涨的七大因素(下篇)
  19. php generator 风雪,PHP 生成器Generator理解
  20. 数字化时代-6:从经济体所有制看赚钱的规模

热门文章

  1. python从入门到放弃篇26(lxml.etree库,urllib.request库,构造xpath路径,构造url)实现翻页爬取豆瓣书简介并保存数据
  2. android手机怎么连电视,智能电视怎么连接手机?这三种方法满足你各种需求
  3. 编译方舟编译器源码教程
  4. 是男人就撑100秒自制版(VB)
  5. C#之禁用任务管理器(对注册表项的访问被拒绝)
  6. pg_ctl开启pg数据库时出现未找到命令
  7. 本体编辑和知识获取软件--protege汉化版
  8. c语言中exit(0)的作用,C语言中exit(0)与exit(1)有什么区别??
  9. HP中国区总裁的忠告
  10. word默认文字环绕方式是什么_在word2010中,艺术字默认的文字环绕方式