欢迎关注微信公众号 C#编程大全 这里有更多入门级实例帮你快速成长

在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. 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\"";
    else
    connString = "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;
    }
    }
    #endregion private 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
    }
    }

      运行效果:

    小编微信号z438679770

C# excel文件导入导出的更多相关文章

  1. NodeJs之EXCEL文件导入导出MongoDB数据库数据

    NodeJs之EXCEL文件导入导出MongoDB数据库数据 一,介绍与需求 1.1,介绍 (1),node-xlsx : 基于Node.js解析excel文件数据及生成excel文件. (2),ex ...

  2. Excel导入导出工具(简单、好用且轻量级的海量Excel文件导入导出解决方案.)

    Excel导入导出工具(简单.好用且轻量级的海量Excel文件导入导出解决方案.) 置顶 2019-09-07 16:47:10 $9420 阅读数 261更多 分类专栏: java   版权声明:本 ...

  3. Excel文件导入导出(基于Nodejs、exceljs)

    Excel导入.导出是大多数项目的管理后台必备功能.几年来使用过多个该功能的实现包,最近一次开发该功能,突然发现一个人气极高(3000+)的包,这里记录一下使用方法. 大凡厉害的技术的文档咋一看都想字 ...

  4. Excel文件导入导出

    /**     * 导入Excel文件数据     *      * @param file 将要导入的Excel文件     * @param fileCheckKeyWord 用于判断导入文件是否 ...

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

    1.导入的测试方法 选择form-data,key值填写方法对应的参数,选择File,Value处上传文件即可. 2. 导出的测试方法 在导出文件的时候,响应结果是乱码,然后在测试的时候选择下载,下载 ...

  6. 用NODEJS处理EXCEL文件导入导出,文件上传

    參考文章 http://librajt.github.io/2013/08/04/handle-excel-file-with-nodejs/ 对照了 ExcelJS ,https://github. ...

  7. CSV文件导入导出MySQL

    使用SQLyog 工具导入文件数据到MySQL: Excel文件导入导出: 需要驱动:Microsoft Office 2007驱动 导入需要注意的问题:1.Excel里数值列,默认导入会变成浮点型. ...

  8. c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出

    c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出 using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using S ...

  9. Laravel Excel 实现 Excel-CSV 文件导入导出功能

    Laravel Excel 是一款基于 PHPExcel 开发的Laravel框架专用的 Excel/CSV 文件导入导出功能的扩展包,用起来的非常方便. 它的 Github 地址是:https:// ...

随机推荐

  1. ctf常见源码泄露

    前言 在ctf中发现很多源码泄露的题,总结一下,对于网站的搭建要注意删除备份文件,和一些工具的使用如git,svn等等的规范使用,避免备份文件出现在公网 SVN源码泄露 原理 SVN(subversi ...

  2. [BUUOJ记录] [BJDCTF2020]The mystery of ip

    本题考察XFF头的ssti模板注入,没有过滤,算是入门题 进入题目hint.php的源码中可以看到一个hint 猜测是通过XFF头来获取信息的,发个HTTP请求添加一个XFF头测试一下: GET /f ...

  3. Activiti7 学习总结

    什么是工作流? 就是通过计算机对业务流程进行自动化处理,实现多个参与者按照预定义的流程去自动执行业务流程 什么是Activiti? Activiti是一个工作流引擎,开源的架构,基于BPMN2.0标准 ...

  4. Oracle12C安装配置文档

    Oracle12C安装配置文档   Oracle12C安装配置文档 准备软件: 开始安装: 打开从官网下载下来的两个压缩包,进行解压 打开解压好的后缀为2of2的文件夹找到路径为database下的“ ...

  5. TaskContinuationsOptions.ExecuteSynchronously探秘

    TPL - Task Parallel Library为我们提供了Task相关的api,供我们非常方便的编写并行代码,而不用自己操作底层的Thread类.使用Task的优势是显而易见的: 提供返回值 ...

  6. PHP生成二维码 endroid/qr-code 扩展包

    目录 1. 引入 endroid/qr-code 扩展包 2. 使用示例 3. 二维码中放入logo,无法识别二维码的问题 1. 引入 endroid/qr-code 扩展包 https://pack ...

  7. 单元测试unittest(基于数据驱动的框架:unittest+HTMLTestRunner/BeautifulReport+yaml+ddt)

    一.定义 unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行,该测试框架可组织执行测试用例,并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果 ...

  8. markdown基本语法说明

    作为一个java程序员,要接触的东西很多,时不时 就要学习,最近写文档的时候发现,markdown很有意思,就记录下来,作为一个简单的说明和学习 :    1.标题 # 这是一级标题 ## 这是二级标 ...

  9. Fliptile(POJ 3279)

    原题如下: Fliptile Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 16494   Accepted: 6025 D ...

  10. oracle分区怎么使用

    1.什么是分区 分区的实质是把一张大表的数据按照某种规则使用多张子表来存储.然后这多张子表使用统一的表名对外提供服务,子表实际对用户不可见.类似于在多张子表上建立一个视图,然后用户直接使用该视图来访问 ...