【转】教你用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,如需转载请自行联系原作者

相关文章
|
4月前
|
移动开发 JavaScript
(H5查看CAD)网页CAD提取图纸表格到excel
本文介绍如何通过自定义MxCAD插件,在Web端智能识别CAD图纸中的表格,实现自动合并与高效导出至Excel,提升数据提取效率与准确性。内容涵盖区域选择、图形识别、表格结构重建、单元格合并及内容导出等关键技术,适用于工程图纸数据自动化处理场景。
|
Java API Apache
Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
【10月更文挑战第29天】Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
869 5
|
10月前
|
物联网 数据处理 C#
C#实现上位机开发,串口通信,读写串口数据并处理16进制数据
C#实现上位机开发,串口通信,读写串口数据并处理16进制数据。在自动化、物联网以及工业控制行业中,上位机开发是一项重要的技能。本教程主要介绍使用C#进行上位机开发,重点在于串口通信和数据处理。
1866 82
|
9月前
|
JavaScript 前端开发 数据可视化
20.6K star!Excel级交互体验!这款开源Web表格神器绝了!
Handsontable 是一款功能强大的 JavaScript 数据表格组件,提供类 Excel 的交互体验。支持实时协作、数据绑定、公式计算等企业级功能,可轻松集成到 React/Vue/Angular 等主流框架。
1579 11
|
9月前
|
人工智能 数据可视化 前端开发
Probly:开源 AI Excel表格工具,交互式生成数据分析结果与可视化图表
Probly 是一款结合电子表格功能与 Python 数据分析能力的 AI 工具,支持在浏览器中运行 Python 代码,提供交互式电子表格、数据可视化和智能分析建议,适合需要强大数据分析功能又希望操作简便的用户。
1138 2
|
SQL 数据可视化 数据挖掘
想让Excel表格设计更美观?试试这几款好用工具!
Excel表格设计在项目管理和数据分析中至关重要。本文推荐四款辅助工具:板栗看板、Excel自动图表助手、Think-Cell Chart 和 Power BI,分别在任务管理、图表生成、数据可视化等方面表现突出,帮助你设计出更专业、美观的表格。
1185 2
|
JavaScript 前端开发 数据处理
Vue导出el-table表格为Excel文件的两种方式
Vue导出el-table表格为Excel文件的两种方式
805 6
|
Python
python读写操作excel日志
主要是读写操作,创建表格
163 2
|
前端开发 JavaScript API
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
1176 0
|
索引 Python
Excel学习笔记(一):python读写excel,并完成计算平均成绩、成绩等级划分、每个同学分数大于70的次数、找最优成绩
这篇文章是关于如何使用Python读取Excel文件中的学生成绩数据,并进行计算平均成绩、成绩等级划分、统计分数大于70的次数以及找出最优成绩等操作的教程。
412 0

热门文章

最新文章