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

目录

1 添加excel引用

2 添加名称空间

3 完整代码与界面展示


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

1 添加excel引用

2 添加名称空间

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

3 完整代码与界面展示

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

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

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
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小薛引路

喜欢的读者,可以打赏鼓励一下

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值