【C#】27. 比较工具EXCEL Addin

32 篇文章 0 订阅
7 篇文章 0 订阅
<pre name="code" class="plain">
 


using Microsoft.Office.Tools.Ribbon;
using Microsoft.Office.Interop.Excel;
using System.Diagnostics;

namespace MyTools
{
    public partial class MainRibbon
    {
        //定义成员
        private Worksheet ws;
        private Range rgA;
        private Range rgB;
        private void MainRibbon_Load(object sender, RibbonUIEventArgs e)
        {

        }

        确定 Range A 的范围
        private void btnRangeA_Click(object sender, RibbonControlEventArgs e)
        {
            ws = Globals.ThisAddIn.Application.ActiveSheet;
            edBoxRangeA.Text = ws.Application.Selection.Address;
        }

        确定 Range B 的范围
        private void btnRangeB_Click(object sender, RibbonControlEventArgs e)
        {
            ws = Globals.ThisAddIn.Application.ActiveSheet;
            edBoxRangeB.Text = ws.Application.Selection.Address;
        }

        //返回结果 A - B,即在A中但是不在B中的元素
        private void btnCompare_Click(object sender, RibbonControlEventArgs e)
        {
            int i, j, curRow, curCol;
            object[] objA, objB;
            //输入 rgA 和 rgB
            rgA = ws.Application.get_Range(edBoxRangeA.Text);
            rgB = ws.Application.get_Range(edBoxRangeB.Text);
            //传入到数组objA, objB
            objA = new object[rgA.Count];
            objB = new object[rgB.Count];
            for (i = 0; i < objA.Length; i++)
            {
                objA[i] = rgA[i + 1, 1].Value;
            }
            for (i = 0; i < objB.Length; i++)
            {
                objB[i] = rgB[i + 1, 1].Value;
            }
            //记录活动单元格的位置
            curRow = ws.Application.ActiveCell.Row;
            curCol = ws.Application.ActiveCell.Column;
            try
            {
                //在rgA中但是不在rgB中的元素
                for (i = 0; i < objA.Length; i++)
                {
                    for (j = 0; j < objB.Length; j++)
                    {
                        if (objA[i].GetType() == objB[j].GetType())
                        {
                            if (objA[i].ToString() == objB[j].ToString())
                            {
                                break;
                            }
                        }
                    }
                    if (j >= objB.Length)
                    {
                        //在Activated cell中输出结果
                        ws.Application.Cells[curRow, curCol].Value = objA[i];
                        curRow += 1;
                    }
                }
                if (curRow==ws.Application.ActiveCell.Row)
                {
                    ws.Application.Cells[curRow, curCol].Value = "No element is in A but not in B ! ";
                }
            }
            catch (System.Exception exception)
            {
                ws.Application.ActiveCell.Value = exception.Message;
            }
        }

        //交换 A 和 B 的范围
        private void btnSwap_Click(object sender, RibbonControlEventArgs e)
        {
            string tempAddress;
            ws = Globals.ThisAddIn.Application.ActiveSheet;
            tempAddress = edBoxRangeA.Text;
            edBoxRangeA.Text = edBoxRangeB.Text;
            edBoxRangeB.Text = tempAddress;
        }

    }
}

武汉派先科技有限公司推出的<>专业版是市场上最为强大便捷的Excel比较工具。它为工作中经常需要进行数据比较的用户提供了完美的解决方案。无论你的数据是存放在Excel文件,还是存放在文本文件,或者存放在Access、Microsoft SQL数据库,<>专业版都可以提供快速比较,大量节省您的时间和精力,将您从枯燥冗长的数据海洋中解放出来,从而让您的工作变得轻松愉快。 <>专业版不同于其它同类产品。其它同类产品在比较时候,要么是一个插件,要么需要显式地在前台运行Excel程序。而百分百比较Excel完全独立运行,与后台的Excel程序协同完成工作,不需要来回切换程序。 本产品的主要特性点: 1、 支持对任意Excel内容的比较比较整个工作簿(workbook),并且可以对工作簿中的每个工作表进行单独的比较设置 • 比较整个工作表(worksheet),并允许多种比较设置 • 比较工作表中的已命名区域(named range),并允许多种比较设置 • 比较工作表中用户运行时自由选定的任何区域(range),并允许多种比较设置 2、 支持对远程数据比较 • 支持从文本文件(Text/CSV)中导入数据比较 • 支持从Access数据库中导入数据比较 • 支持从微软SQL数据库中导入数据比较 3、支持灵活的多种比较设置 • 支持按第一行名字配对比较 • 支持按Excel所在列位置配对比较 • 支持按范围(range)内的单元坐标配对比较 (同一坐标的单元配对比较) • 支持用户自由定义的列映射配对比较 • 支持值和公式的比较 • 支持大小写区分 • 所有的比较设置均可保存供下次调用 4、自动生成XML格式的比较结果报表 • XML格式保留对差异单元的加亮显示 • XML格式使您的生意伙伴对比较结果的自动再处理(程序处理)成为可能 • XML格式允许没有安装微软Excel的生意伙伴用互联网浏览器进行显示比对 • XML格式也允许你在Excel中对比较结果进行显式和分析 5、原始Excel文件和比较结果显示在同一个程序窗口中,无需切换 6、可一键快速定位比较结果对应的原始Excel单元 7、独特的比较算法,即使大量的数据也可快速比较 8、友好的用户界面,让你的操作轻松自如.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值