【转】教你用C#读写、删除、更新excel表格记录

简介:

 

文章出处:http://blog.csdn.net/kuangshazi515/article/details/6585118                                                                                                                            

如下图所示,编一个程序,鼠标单击窗体视图区(右边)时,获取一对坐标(X,Y),点击保存将点保存到excel表记录中。此外,还实现了删除、更新功能以及打开excel表功能。插入和更新比较简单,和操作一般的数据库一样,但是删除稍微有点复杂,不能用delete from [Sheet1$] where ID=x的方式删除,自己可以去试,主要是excel数据之间的关系不像关系数据库那么简单,oledb不提供这种方法。所以只能用专门操作excel表的(Microsoft.Office.Interop.Excel名字空间下,先添加引用)来实现删除某条记录的功能。

 

源代码:

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Text;

using System.Windows.Forms;

using System.Data.OleDb;

using System.Reflection;

using Excel = Microsoft.Office.Interop.Excel;

 

namespace Leation

{

    public partial class FrmMain : Form

    {

        //定义变量

        private OleDbConnection connection = null;

        private OleDbCommand cmd = null;

        private OleDbDataAdapter dataAdapter = null;

        private DataSet dataSet = null;

        private string filePath = @"G:\points.xls";

        private string connStr = "provider=microsoft.jet.oledb.4.0;data source=G:\\points.xls;extended properties='Excel 8.0;HDR=yes;IMEX=2'";

        private string selectStr = "select * from [Sheet1$]";

        private string cmdStr = null; 

        private string OID = null;    //对象ID

        private string x = null;

        private string y = null;

        private Excel.Application excelApp = null;

        private Excel.Workbook book = null;

        private Excel.Worksheet sheet = null;

        private Excel.Range range = null;

 

        //构造函数

        public FrmMain()

        {

            InitializeComponent();

        }

 

        //鼠标移动事件

        private void splitContainer1_Panel2_MouseMove(object sender, MouseEventArgs e)

        {

            this.lblxy.Text = "x=" + e.X.ToString() + "  y=" + e.Y.ToString();

        }

 

        //鼠标按下事件

        private void splitContainer1_Panel2_MouseDown(object sender, MouseEventArgs e)

        {

            if (e.Button == MouseButtons.Left)

            {

                this.tbX.Text = e.X.ToString();

                this.tbY.Text = e.Y.ToString();

            }

        }

 

        //刷新dataGridView1

        private void RefreshTable()

        {

            connection = new OleDbConnection(connStr);

            connection.Open();

            dataAdapter = new OleDbDataAdapter(selectStr, connection);

            dataSet = new DataSet();

            dataAdapter.Fill(dataSet);

            this.dataGridView1.DataSource = dataSet.Tables[0];

            connection.Close();

        }

 

        //程序加载事件,初始化dataGridView1

        private void FrmMain_Load(object sender, EventArgs e)

        {

            this.RefreshTable();

        }

 

        //获取一个可以用的OID

        private string GetOID()

        {

            int rowNum = this.dataGridView1.Rows.Count - 1;

            int maxOID = 0;

            int temp = 0;

            for (int i = 0; i < rowNum; i++)

            {

                temp = int.Parse(this.dataGridView1[0, i].Value.ToString());

                if (maxOID < temp)

                {

                    maxOID = temp;

                }

            }

            return (maxOID+1).ToString();

        }

 

        //插入一条记录,即保存一个点信息

        private void btnSavePnt_Click(object sender, EventArgs e)

        {

            OID = this.GetOID();

            x = this.tbX.Text;

            y = this.tbY.Text;

            if (x == "" || y == "")

            {

                MessageBox.Show("x,y不能为空");

                lblTip.Text = "保存失败";

                return;

            }

            connection = new OleDbConnection(connStr);

            connection.Open();

            cmdStr = "insert into [Sheet1$](ID,X,Y) values(" + OID + "," + x + "," + y + ")";

            cmd = new OleDbCommand(cmdStr, connection);

            int row=cmd.ExecuteNonQuery();

            if (row > 0)

            {

                lblTip.Text = "保存成功,插入行数:" + row.ToString();

            }

            else

            {

                lblTip.Text = "保存失败";

            }

            connection.Close();

            this.RefreshTable();

        }

 

        //删除记录

        private void btnDelSelRow_Click(object sender, EventArgs e)

        {

            int selRowIndex = this.dataGridView1.CurrentRow.Index + 2;   //excel表中的行索引与dataGridView不一样,这里注意

            if (selRowIndex<1)

            {

               MessageBox.Show("没有选中行");

               lblTip.Text = "删除失败";

               return;

            }

            excelApp = new Microsoft.Office.Interop.Excel.Application();

            excelApp.Visible = false;   //若为true,删除瞬间可以看见 office excel界面

            //打开excel文件

            book = excelApp.Workbooks.Open(filePath, Missing.Value,false, Missing.Value, Missing.Value, Missing.Value, true, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);

            //获取sheet1

            sheet = (Excel.Worksheet)book.Worksheets[1];

            //获取编辑范围

            range = (Excel.Range)sheet.Rows[selRowIndex, Missing.Value];

            //删除整行

            range.EntireRow.Delete(Excel.XlDeleteShiftDirection.xlShiftUp);

            //保存编辑

            book.Save();

            //关闭book

            book.Close(Missing.Value, Missing.Value, Missing.Value);

            //退出excel application,可以将前面的excelApp.Visible = false改为excelApp.Visible = true看看;

            excelApp.Workbooks.Close();               

            excelApp.Quit();

            //刷新dataGridView1

            this.RefreshTable();

            //选中删除行的上一行

            if ((selRowIndex - 3) > 0)

            {

                this.dataGridView1.Rows[selRowIndex - 3].Selected = true;

            }

            this.lblTip.Text="删除成功";

        }

 

        //更新记录

        private void btnUpdate_Click(object sender, EventArgs e)

        {

            int selRowIndex= this.dataGridView1.CurrentRow.Index;

            if (selRowIndex< 0)

            {

                MessageBox.Show("没有选中行!");

                lblTip.Text = "更新失败";

                return;

            }

            OID = this.dataGridView1[0, selRowIndex].Value.ToString();

            x = this.tbX.Text;

            y = this.tbY.Text;

            if (x == "" || y == "")

            {

                MessageBox.Show("x,y不能为空");

                lblTip.Text = "更新失败";

                return;

            }

            connection = new OleDbConnection(connStr);

            connection.Open();

            cmdStr = "update [Sheet1$] set X="+x+",Y="+y+" where ID='"+OID+"'";

            cmd = new OleDbCommand(cmdStr, connection);

            int row = cmd.ExecuteNonQuery();

            if (row >= 1)

            {

                lblTip.Text = "更新成功,更新行数:" + row.ToString();

            }

            else

            {

                lblTip.Text = "更新失败";

            }

            connection.Close();

            this.RefreshTable();

            //选中更新的行

            this.dataGridView1.Rows[selRowIndex].Selected = true;

        }

 

        private void btnOpenFile_Click(object sender, EventArgs e)

        {

            OpenFileDialog ofd = new OpenFileDialog();

            ofd.Filter = "excel文件(*.xls)|*.xls";

            ofd.Title = "代开excel表";

            if (ofd.ShowDialog() == DialogResult.OK)

            {

                this.filePath = ofd.FileName;

                this.connStr = "provider=microsoft.jet.oledb.4.0;data source=" + filePath + ";extended properties='Excel 8.0;HDR=yes;IMEX=2'";

                this.RefreshTable();

            }

        }

       

      

    }

}

 

没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。





    本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/arxive/p/3481427.html,如需转载请自行联系原作者

相关文章
|
7天前
|
Java API Apache
Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
【10月更文挑战第29天】Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
42 5
|
2天前
|
SQL 数据可视化 数据挖掘
想让Excel表格设计更美观?试试这几款好用工具!
Excel表格设计在项目管理和数据分析中至关重要。本文推荐四款辅助工具:板栗看板、Excel自动图表助手、Think-Cell Chart 和 Power BI,分别在任务管理、图表生成、数据可视化等方面表现突出,帮助你设计出更专业、美观的表格。
12 2
|
15天前
|
JavaScript 前端开发 数据处理
Vue导出el-table表格为Excel文件的两种方式
Vue导出el-table表格为Excel文件的两种方式
|
18天前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
48 2
|
2月前
|
SQL C# 数据库
EPPlus库的安装和使用 C# 中 Excel的导入和导出
本文介绍了如何使用EPPlus库在C#中实现Excel的导入和导出功能。首先,通过NuGet包管理器安装EPPlus库,然后提供了将DataGridView数据导出到Excel的步骤和代码示例,包括将DataGridView转换为DataTable和使用EPPlus将DataTable导出为Excel文件。接着,介绍了如何将Excel数据导入到数据库中,包括读取Excel文件、解析数据、执行SQL插入操作。
EPPlus库的安装和使用 C# 中 Excel的导入和导出
|
24天前
|
前端开发 JavaScript API
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
110 0
|
30天前
|
索引 Python
Excel学习笔记(一):python读写excel,并完成计算平均成绩、成绩等级划分、每个同学分数大于70的次数、找最优成绩
这篇文章是关于如何使用Python读取Excel文件中的学生成绩数据,并进行计算平均成绩、成绩等级划分、统计分数大于70的次数以及找出最优成绩等操作的教程。
55 0
|
1月前
|
Java Apache
Apache POI java对excel表格进行操作(读、写) 有代码!!!
文章提供了使用Apache POI库在Java中创建和读取Excel文件的详细代码示例,包括写入数据到Excel和从Excel读取数据的方法。
34 0
对excel读写的三个模块,xlsxwriter最牛,xlwt , xlrd,openpyxl
对excel读写的三个模块,xlsxwriter最牛,xlwt , xlrd,openpyxl
|
3月前
|
人工智能 BI
用ChatGPT做excel表格真香!只需动嘴提要求和复制粘贴
用ChatGPT做excel表格真香!只需动嘴提要求和复制粘贴