Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> OA  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701855
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

Excel中如何返回差集

作者:cg1  摘自:access911.net  :cg1  更新日期:2011-11-23  浏览人次:

 

问题:

Excel中有Application.Intersect可以返回交集,那么如何返回差集呢?

 

回答:

使用后的实际效果请参考以下链接:
http://www.access911.net/online/assist911.htm#_Toc314580812

当按住Ctrl键多选非连续单元格时,如果错误选择后是无法取消该选择,使用本功能就可以选取或者取消选取。这在财务日常工作中是很有用的,因为财务经常要多选不同的数据,快速查看Excel右下角的求和值与财务报表值是否相同。
图片如下:
按此在新窗口浏览图片

要添加选择区域时可以不用按住Ctrl键,而是直接右键单击选定区域,选择“添加选择区域”
图片如下:
按此在新窗口浏览图片

如果要取消其中某个单元格的选择时,只需要点击取消选择区域
图片如下:
按此在新窗口浏览图片

最终单击显示选择区域
图片如下:
按此在新窗口浏览图片

得到如下图的效果
图片如下:
按此在新窗口浏览图片

上述操作的核心要点就是如何选择A区域与B区域的差集,以下就是核心代码。

假定A1:I30中已经有数据了,假定当前用户的选择区域是 $D$3,$B$3:$B$7,$C$10:$G$24


'获取已使用区域与被选定区域的差集
Function GetSetDifferentCells() As Range
    Dim src As Range, sel As Range
    Dim Result As Range
    Dim cl As Range
    
    '假定A1:I30中已经有数据了
    Set src = ActiveSheet.UsedRange
    '假定当前用户的选择区域是$D$3,$B$3:$B$7,$C$10:$G$24
    Set sel = Application.Selection
    Debug.Print sel.Address
    
    For Each cl In src
        Debug.Print "current:" & cl.Address
        If Not Result Is Nothing Then
            Debug.Print "result:" & Result.Address
        
        End If
        
        
        If Application.Intersect(cl, sel) Is Nothing Then
            If Not Result Is Nothing Then
                Set Result = Application.Union(Result, cl)
            Else
                Set Result = cl
            End If
        End If
    Next cl
    
    Set GetSetDifferentCells = Result
    GetSetDifferentCells.Select
End Function


 

 

 
相关文章
     没有手动相关文章
     如何解决Excel2007提示“发现不可读取的内容”的问题?
     如何在EXCEL中截图,并将图片保存为GIF或者JPG格式
     如何在Excel2003的工作表中加入标尺功能,以厘米为单位?
     Excel当有多列合并单元格时如何只选中其中一列?
     如何在导出表到EXCEL时让用户随意选择字段?
     如何将整个 MDB 中所有的表全部导出到一个 XLS 中去?
     一个将数据导出到EXCEL的存储过程
     新手来看:excel中怎么编程获取单元格字符颜色、背景、批注?
     新手来看:我是否可以将Excel数据导入?
     新手来看:如何将数据表导出备份到excel表格
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利