C#编程学习21:修改excel的数据项

简介: C#编程学习21:修改excel的数据项

需求说明:给定表格要修改指定项目的值

1 添加excel引用

20190711134727344.png

2 添加名称空间

1. using myExcel = Microsoft.Office.Interop.Excel;
2. using System.Reflection;//为了调用缺省方法Missing


3 完整代码与界面展示

使用方法:制定数据项的行数和要设定的值,点击单项修改,添加设定值到数据表中;

多项数据添加完毕后,点击数据导出,即可输出修改后的数据记录


20190711135141359.png

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using myExcel = Microsoft.Office.Interop.Excel;
using System.Reflection;//为了调用缺省方法Missing
namespace excelOper
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        myExcel.Application excelApp = new myExcel.Application();
        myExcel.Workbook excelDoc; //Excel文档变量
        myExcel.Worksheet ws;
        private void button1_Click(object sender, EventArgs e)
        {
            //myExcel.Application excelApp = new myExcel.Application(); //Excel应用程序变量,初始化
            string inputFileName = @"E:\C#\Example200\excelOper\excelOper\my.xlsx";          
            excelDoc = excelApp.Workbooks.Open(inputFileName);
            ws = (myExcel.Worksheet)excelDoc.Sheets[1];
            modify(ws);
            MessageBox.Show("执行完毕");
        }
        ///<summary>
        /// 获取指定文件的指定单元格内容
        ///</summary>
        /// <param name="fileName">文件路径</param>
        /// <param name="row">行号</param>
        /// <param name="column">列号</param>
        /// <returns>返回单元指定单元格内容</returns>
        public string getExcelOneCell(string fileName, int row, int column)
        {
            Microsoft.Office.Interop.Excel.Application app = new Microsoft.Office.Interop.Excel.Application();
            Microsoft.Office.Interop.Excel.Workbook wbook = app.Workbooks.Open(fileName, Type.Missing, Type.Missing,
                 Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing,
                 Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing,
                 Type.Missing, Type.Missing);
            Microsoft.Office.Interop.Excel.Worksheet workSheet = (Microsoft.Office.Interop.Excel.Worksheet)wbook.Worksheets[1];
            string temp = ((Microsoft.Office.Interop.Excel.Range)workSheet.Cells[row, column]).Text.ToString();
            wbook.Close(false, fileName, false);
            app.Quit();
            NAR(app);
            NAR(wbook);
            NAR(workSheet);
            return temp;
        }
        //此函数用来释放对象的相关资源
        private void NAR(Object o)
        {
            try
            {
                //使用此方法,来释放引用某些资源的基础 COM 对象。 这里的o就是要释放的对象
                System.Runtime.InteropServices.Marshal.ReleaseComObject(o);
            }
            catch { }
            finally
            {
                o = null; GC.Collect();
            }
        }
        private void modify(myExcel.Worksheet ws)
        {
            if (textBox1.Text == "" || textBox2.Text == "")
            {
                MessageBox.Show("修改数据行号或设定数据项为空", "错误提示");
                return;
            }
            int row = int.Parse(textBox1.Text);
            string temp = ((myExcel.Range)ws.Cells[row, 1]).Text.ToString();
            ws.Cells[row, 2] = textBox2.Text;
            textBox3.AppendText(temp + "\t" + textBox2.Text);
            textBox3.AppendText("\n");
        }
        private void button2_Click(object sender, EventArgs e)
        {
            string outputFileName = @"E:\C#\Example200\excelOper\excelOper\modify_my.xlsx";
            object Nothing;
            Nothing = Missing.Value;//给Nothing一个缺省的值
            object format = myExcel.XlFileFormat.xlWorkbookDefault;
            //将excelDoc文档对象的内容保存为XLSX文档
            excelDoc.SaveAs(outputFileName, format, Nothing, Nothing, Nothing, Nothing, myExcel.XlSaveAsAccessMode.xlExclusive, Nothing, Nothing, Nothing, Nothing, Nothing);
            excelDoc.Close(Nothing, Nothing, Nothing);
            //关闭excelApp组件对象
            excelApp.Quit();
            MessageBox.Show("导出完毕");
            System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);
            excelApp = null;
            // 调用垃圾回收
            GC.Collect();
        }
    }
}
相关文章
|
1月前
|
Java API Apache
Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
【10月更文挑战第29天】Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
108 5
|
1月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
32 3
|
20天前
|
Java 物联网 C#
C#/.NET/.NET Core学习路线集合,学习不迷路!
C#/.NET/.NET Core学习路线集合,学习不迷路!
|
3月前
|
SQL C# 数据库
EPPlus库的安装和使用 C# 中 Excel的导入和导出
本文介绍了如何使用EPPlus库在C#中实现Excel的导入和导出功能。首先,通过NuGet包管理器安装EPPlus库,然后提供了将DataGridView数据导出到Excel的步骤和代码示例,包括将DataGridView转换为DataTable和使用EPPlus将DataTable导出为Excel文件。接着,介绍了如何将Excel数据导入到数据库中,包括读取Excel文件、解析数据、执行SQL插入操作。
EPPlus库的安装和使用 C# 中 Excel的导入和导出
|
2月前
excel 百分位函数 学习
excel 百分位函数 学习
30 1
|
2月前
|
IDE 开发工具 数据安全/隐私保护
Python编程--实现用户注册信息写入excel文件
Python编程--实现用户注册信息写入excel文件
21 1
|
3月前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
46 2
|
2月前
|
开发框架 缓存 算法
开源且实用的C#/.NET编程技巧练习宝库(学习,工作,实践干货)
开源且实用的C#/.NET编程技巧练习宝库(学习,工作,实践干货)
|
2月前
|
安全 C# 数据安全/隐私保护
实现C#编程文件夹加锁保护
【10月更文挑战第16天】本文介绍了两种用 C# 实现文件夹保护的方法:一是通过设置文件系统权限,阻止普通用户访问;二是使用加密技术,对文件夹中的文件进行加密,防止未授权访问。提供了示例代码和使用方法,适用于不同安全需求的场景。
119 0
|
3月前
|
安全 程序员 编译器
C#一分钟浅谈:泛型编程基础
在现代软件开发中,泛型编程是一项关键技能,它使开发者能够编写类型安全且可重用的代码。C# 自 2.0 版本起支持泛型编程,本文将从基础概念入手,逐步深入探讨 C# 中的泛型,并通过具体实例帮助理解常见问题及其解决方法。泛型通过类型参数替代具体类型,提高了代码复用性和类型安全性,减少了运行时性能开销。文章详细介绍了如何定义泛型类和方法,并讨论了常见的易错点及解决方案,帮助读者更好地掌握这一技术。
80 11