首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

VBA技巧:当单元格域中包含由公式返回单元格时,如何判断?

标签:VBAVBA中,我们经常会遇到需要检查某个单元格区域是否为空情形。我们可以使用下面程序中代码来检查单元格区域是否为空。..." Else MsgBox "单元格区域为空" End If End Sub 然而,如果单元格区域偶然包含一个返回为空公式,则上述代码不会将该单元格区域返回为空,因为它包含公式返回为空单元格...要处理这个问题,可以使用下面的命令来检查单元格区域是否为空,即使该单元格区域包含返回空公式。..." Else MsgBox "单元格不全为空单元格" End If End Sub 还可以使用Find方法来判断,如下面的代码: Sub CheckIfBlandAdd2..." Else MsgBox "单元格不全为空单元格" End If End Sub 这将同时适用于任意连续单元格区域。

2K10
您找到你想要的搜索结果了吗?
是的
没有找到

VBA自定义函数:在单元格域中创建不重复随机数

标签:VBA,自定义函数 有时候,我们需要创建一组不重复随机组,例如在指定单元格域中创建一组不重复随机数用于模拟数据分析。 下面的一个VBA自定义函数,可用于创建指定数值范围不重复随机数。...As Long '要选择随机值数目 (默认为全部) Dim TempArray_Source() '保存最小值到最大值源列表 Dim TempArray_Result...() '保存随机选择结果 (随机排序) Dim SrcULimit As Long '源数组上限....Exit Function End If If NumberOfRandoms > (MaxValue - MinValue + 1) Then MsgBox "要求返回数字超过给定范围内可能数量...Next Result_Index Application.ScreenUpdating = True RandomSeq = TempArray_Result End Function 要在单元格区域

21010

VBA实用小程序68:判断指定单元格域中是否存在重复值

excelperfect 有时候,我们可能想要知道某一域中是否输入了重复值,这样好做进一步处理。...rngCell As Range ‘绑定Dictionary对象 Set oDic =CreateObject("Scripting.Dictionary") ‘遍历指定单元格域中单元格...'单元格域中单元格数量 '表明存在重复值,返回True '否则不存在重复值,返回False If oDic.Count rng.Cells.Count Then...代码中,参数rng代表要判断单元格区域。...图1 注:由于疏忽,先推送了VBA实用小程序69,将VBA实用小程序67和68漏掉了,这两天陆续补上。谢谢有心人“深海”朋友提醒! 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。

2.2K10

Excel VBA解读(140): 从调用单元格中获取先前计算

学习Excel技术,关注微信公众号: excelperfect 如果有一个依赖于一些计算资源用户定义函数,可能希望该用户定义函数在大多数情况下只返回其占用单元格中最后一次计算得到值,并且只偶尔使用计算资源...假设要给用户定义函数传递一个计算资源参数,并让一个开关告诉它何时使用计算资源。...可以设置开关(这里使用称为“RefreshSlow”已定义名称)并在VBA过程中刷新用户定义函数,如下所示: Sub RefreshUDFs() Dim lCalcMode As Long...下面是名为PREVIOUSXLL+函数代码,该函数具有使其成为易失性或非易失性参数。(命令等效函数默认为易失性,但在使用它将前一个值传递给VBA用户定义函数时,通常希望它是非易失性)。...小结 有几种方法可以从VBA用户定义函数最后一次计算中获取先前值,但最好解决方案需要使用C++ XLL。

6.7K20

使用VBA快速给所选择多个单元格区域绘制矩形边框

下面的代码能够给当前工作表中所选择单元格区域绘制红色矩形边框。 首先,选取想要绘制边框所有单元格区域,可以在选择单元格区域同时按住Ctrl键,从而选取多个单元格区域。...然后,运行下面的代码,VBA会自动给所选单元格区域周边绘制红色边框,效果如下图1所示。...selectedAreas.Left, selectedAreas.Top, _ selectedAreas.Width, selectedAreas.Height) '修改所创建形状属性...,也可以使用VBA快速完成,代码如下: Sub deleteRedRectBox() Dim shp As Shape '遍历当前工作表中每个形状 For Each shp In ActiveSheet.Shapes...If Next shp End Sub 可以看到,这种情形使用VBA代码很方便,避免了你选择单元格区域然后进行一系列格式设置频繁操作。

59320

Excel VBA解读(143): 在自定义函数中使用整列引用时,如何更有效率?

VBA用户自定义函数中处理此问题标准方法是获取整列引用和已使用单元格区域交叉区域,以便用户自定义函数只需处理实际使用整列一部分。...下面的示例VBA代码处理交叉区域,然后返回输入区域中行数和已使用域中行数较小者。...问题是自定义函数会对传递给其每个单元格区域进行检查,即使它不是真正需要。 影响运行时间实际上是包含数据或格式(或以前包含数据或格式)单元格数量,而不是已使用单元格域中最后一个单元格。...然后,只有为每个工作表请求已使用单元格区域第一个用户自定义函数使用时间来查找已使用单元格区域,并且(假设计算本身不会改变已使用单元格区域)将总是检索正确数字。...这种技术效率较低,因为在每个计算周期中工作表可能被计算几次。 如果想找到包含数据最后一行,当有许多包含数据单元格时,使用Range.Find会更快。

2.8K20

VBA小技巧10:删除工作表中错误值

这里将编写VBA代码,用来删除工作表指定区域中错误值,这在很多情况下都很有用。 如下图1所示,有一组数据,但其中有一些错误值,我们想要自动删除这些错误值。 ?...图1 删除错误值数据表如下图2所示。 ? 图2 如果不使用VBA,可以使用Excel“定位”功能来实现。...如下图3所示,单击功能“开始”“编辑”组中“查找和选择——定位条件”,弹出“定位条件”对话框。在该对话框中,选取“公式”中“错误”前复选框,如下图3所示。 ?...图3 单击“确定”后,工作表中错误数据单元格会被选择,单击“Delete”键,删除错误值,结果如上图2所示。...函数来判断单元格中是否是错误值,如果是,则设置该单元格为空。

3.3K30

如何使用VBA统计字符串中某个特定字符

标签:VBA,Split函数 如果要统计某单元格中指定某特定字符数量,可以使用LEN/SUBSTITUTE函数组合经典公式(假设字符串位于单元格B2): =LEN(B2)-LEN(SUBSTITUTE...图1 如果要统计单元格区域(示例中为单元格区域B2:B5)中包含指定某特定字符数量,可以使用下面的公式: =SUMPRODUCT(LEN(B2:B5)-LEN(SUBSTITUTE(LOWER(B2...如果要统计单元格B2中字符“f”数量使用代码: UBound(Split(LCase(Range("B2")),"f")) 代码使用Split函数以字母“f”为分隔符对字符串拆分,拆分后获得数组上限值与字符数相等...如果要统计单元格区域B2:B5中字符“f”数量使用代码: UBound(Split(LCase(Join(WorksheetFunction.Transpose(Range("B2:B5")))),..."f")) 代码使用Join函数将单元格域中字符串联接,然后使用Split函数以字母“f”为分隔符对字符串拆分,拆分后获得数组上限值与字符数相等。

5.1K10

VBA程序:对加粗单元格值求和

标签:VBA 下面的VBA自定义函数演示了如何对应用了粗体格式单元格求和。...ErrHandler: '检查是否溢出 If Err.Number = 6 Then SumBold = CVErr(xlErrNum) Resume Continue End Function 注意,当求和单元格域中单元格格式发生更改时...,不会触发任何事件;而使用Application.Volatile语句,每当在工作表上内容更改时,单元格都会重新计算。...这意味着,仅对求和单元格域中单元格设置加粗格式,使用该自定义函数求和值不会改变,除非按F9键强制计算,或者在工作表中输入内容导致工作表重新计算。...这个程序也提供了一个模板,可以稍作修改对其它格式设置单元格来求和

14410

使用VBA获取单元格背景色中红色、绿色和蓝色数值

标签:VBA 我们可以使用VBA代码来获取单元格背景色中RGB值,如下图1所示。 图1 列B、C、D中单元格值就是列A中相应单元格背景色RGB值。...下面是将单元格背景色拆分成RGB数字表现形式自定义函数: Function Red(rng) As Long Dim c As Long Dim r As Long c = rng.Interior.Color...As Long c = rng.Interior.Color b = c \ 65536 Mod 256 Blue = b End Function 这样,如上图1所示,在单元格...B2中输入: =Red(A2) 在单元格C2中输入: =Green(A2) 在单元格D2中输入: =Blue(A2) 就会得到单元格A2背景色相应RGB值。...如果在其他应用中我们要选择背景色,但却不知道其RGB值,那么就可以先在Excel单元格中设置想要背景色,然后使用这几个函数获取其RGB值,这样就可以应用到其他程序中了。

3.1K30

VBA编程练习04. 在多个单元格区域查找多个数

学习Excel技术,关注微信公众号: excelperfect 本次练习题 如下图1所示工作表,在单元格区域A2:F2中放置是要查找数值;在列H至列BF、行9至行30是被查找区域,这个区域分17...图1 现在,要在这17个小区域中查找单元格区域A2:F2中值并将找到数值个数输入到其下方第32行单元格中。如何使用VBA代码实现? VBA代码 先给出代码,再细细解释。...代码: WorksheetFunction.CountIf(rng(i),Cells(2, j)) 使用工作表函数COUNTIF函数来统计单元格域中指定值数量。...Cells(2,j)分别查找A2至F2中数值,将找到数值个数累加到变量iCount中。最后得到每个小区域中包含数值个数,然后将得到个数值输入到第32行中相应单元格中。...代码中外层循环遍历每个小区域,内层循环遍历A2:F2中值。 小结 1.不要被工作表表面所迷惑,要从中找到规律。 2.有时候,灵活使用工作表函数不失为一个好技巧。 下面是代码图片版: ?

1.5K10

VBA专题10-24:使用VBA操控Excel界面之单元格上下文菜单(Excel 2010及以后版本)

学习Excel技术,关注微信公众号: excelperfect 添加按钮控件 假设你需要对工作表中前面有货币符号值执行计算,然而那些值被解释为文本,你要编写VBA过程来移除所选单元格域中货币符号。...添加其他类型控件 除了上面介绍使用XML代码在单元格上下文菜单中添加按钮控件外,还可以添加6种其他类型内置控件和自定义控件:切换按钮、拆分按钮、菜单、库、复选框和动态菜单。...VBA专题10-23:使用VBA操控Excel界面之添加动态菜单》一文中,当用户激活不同工作表时,在Workbook_SheetActivate事件处理中明确地使菜单无效(为了重新构建菜单)。...然而,如果动态菜单在单元格上下文菜单中,那么不需要编写VBA代码来使菜单无效。当用户右击工作表单元格时,动态菜单在单元格上下文菜单显示其内容过程中重新创建。...然而,使用VBA代码实现添加控件仍然是可能

1.5K10

Excel公式练习55: 获取重复数据出现最大次数

本次练习是:给定一个单元格区域,要求使用公式得到该区域中出现重复次数最多数据重复次数。如下图1所示,在单元格区域A1:F1中,重复次数最多数据是“完美Excel”,重复次数是3。 ?...公式解析 公式可以解析为: =MAX(COUNTIF({"VBA","完美Excel","完美Excel","VBA","Office365","完美Excel"},{"VBA","完美Excel","..."} 数组2:{"VBA","完美Excel","完美Excel","VBA","Office365","完美Excel"} COUNTIF函数依次查找数组2中每个元素在数组1中出现次数,得到数组:...扩展 运用上述技术,可以获取指定数据在单元格域中出现次数,如下图2所示,要求“VBA”和“完美Excel”在单元格区域A1:F1中出现次数。 ?...图2 选择单元格区域A4:B4,输入数组公式: =COUNTIF(A1:F1,A3:B3) 即可获得结果。

3.2K10

Excel VBA编程

sub过程中参数传递 自定义函数,function过程 声明一个自定义函数 使用自己定义函数 function example 设置函数为易失性函数,让自定义函数也能重复计算 操作对象 VBA中常用对象...属性 range对象end属性 value属性——单元格内容 count属性,获得区域中包含单元格个数 通过address属性获取单元格地址 用activate和select方法选中单元格 copy....select range("B1:B10 A4:D6").value range("B6:B10","D2:D8") 用cell属性引用单元格 引用工作表中指定行列交叉单元格 引用单元格域中某个单元格...(2).value=200 '指定工作表第二个单元格为200' 引用整行单元格VBA中,rows表示工作表或某个区域中所有行组成集合,要引用工作表汇总指定行,可以使用行号或者索引号两种方式 activesheet.rows...' 引用整列单元格VBA中,columns表示工作表或某个区域中所有行组成集合,要引用工作表汇总指定行,可以使用行号或者索引号两种方式 activesheet.columns("F:G").select

45.1K21

Excel VBA解读(146): 使用隐式交集处理整列

当Excel希望获得单个单元格引用但却提供给它单元格区域时,Excel会自动计算单元格区域与当前单元格行或列相交区域并使用。例如下图1所示: ?...例如,VLOOKUP函数通常使用单个值或引用作为要查找值,使用单元格区域作为查找表。...例如,公式: =VLOOKUP(A4,$A:$C,3,false) 在列A至列C组成域中精确查找单元格A4中内容,并返回列C中相应值。...并且只将该单个单元格视为从属单元格,因此仅当该单个单元格被改变而不是当该单元格域中任何单元格被改变时,才重新计算公式或函数。...在VBA用户自定义函数(UDF)中运用隐式交集技术 有2种方式可以让隐式交集技术在UDF中自动工作: 1.在函数参数前面放置+号 2.使用VBA来处理隐式交集 例如,下面的简单UDF: Function

4.8K30

VBA专题10-1:使用VBA操控Excel界面之设置单元格格式

本文主要讲解设置工作表单元格单元格区域格式VBA代码,包括设置字体、数字格式、文本对齐、填充单元格背景色、设置单元格边框等。...隐藏单元格内容 示例代码: '隐藏所选单元格域中单元格内容 Selection.NumberFormat= ";;;" 文本对齐 示例代码: '对齐单元格数据 Range("A1").HorizontalAlignment...使用颜色填充单元格 示例代码: '使用指定颜色填充单元格区域背景色 With Range("A1:D3").Interior '设置为xlNone则无填充 .Color = vbBlack '-1(最暗...图2 单元格边框线样式,颜色,宽度 示例代码: '设置单元格区域四个边框(左右上下)边线样式为虚线 Range("A1:C3").Borders.LineStyle= xlDash '设置单元格域中单元格顶部边框线为双线...图3 可以在VBA帮助中查找获取代表线条样式VBA常量值。

6.5K20

Excel实战技巧96:高亮显示内容为同年同月单元格

学习Excel技术,关注微信公众号: excelperfect Excel条件格式是一项很强大很实用功能,能够实现很多需要VBA编码才能实现效果。本文是条件格式一个应用示例。...如下图1所示,在单元格E2中输入年月日后,需要快速在下面的单元格域中找出同年同月日期。 ? 图1 使用“条件格式”功能很容易实现。 1....选择要应用条件格式单元格区域,本例中为单元格区域B4:G11。 2. 单击功能“开始”选项卡中“样式”组中“条件格式——新建规则”命令。 3....在弹出“新建格式规则”对话框中,在“选择规则类型”中选取“使用公式确定要设置格式单元格”,在“为符合此公式值设置格式”中输入: =AND(YEAR(B4)=YEAR(E2),MONTH(B4)=MONTH...当你改变单元格E2中日期后,Excel会自动标识出与其同年同月日期,如下图3所示。 ?

2K10
领券