首页
学习
活动
专区
圈层
工具
发布

使用VBA跨单元格分配值

标签:VBA 这是在exceloffthegrid.com中看到的一个案例,一个非常有用的节省时间的宏:在单元格之间分配值。...假设有一份单个物品的清单,加起来总共210美元,你的老板想额外增加21美元作为应急费用。你打算如何使总额达到231美元?...可以使用公式手动执行此操作,但这将非常耗时;相反,下面的VBA代码只需要2秒钟。...用户单击取消 If apportionValue = False Then Exit Sub '获取布尔值以保留公式或对结果进行硬编码 keepAsFormula = MsgBox("保留公式?"...此时,出现一个输入框,输入要分配的值,如下图2所示。 图2 单击“确定”后,出现一个消息框,如下图3所示,可以选择粘贴新值还是包括公式,单击“确定”。 图3 结果如下图4所示。

1.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    VBA: 禁止单元格移动,防止单元格公式引用失效(2)

    文章背景: 在Excel中,公式引用无效单元格时将显示 #REF! 错误。当公式所引用的单元格被删除或被粘贴覆盖时最常发生这种情况。...为了防止单元格被人不小心移动,可以通过禁用自动填充功能来实现(参见延伸阅读)。...使用VBA代码:Application.CellDragAndDrop = False ,虽然可以避免单元格被移动,但也存在一个问题,如果复制其他工作簿的内容,再回到本工作表内进行粘贴时,发现数据无法粘贴...为了在禁用自动填充功能的同时,依然可以在本工作表内正常跨表粘贴数据,在查阅相关资料之后,找到了可以实现这样要求的VBA代码。 示例: 在本工作簿内,原始数据保存在sheets("源数据")这张表内。...: 禁止单元格移动,防止单元格公式引用失效

    1.9K30

    使用VBA操作Excel公式栏

    标签:VBA 在Excel公式栏中,我们可以看到当前单元格中的内容,或者当前单元格中使用的公式,如下图1所示。 图1 我们也可以使用VBA来操作公式栏,作出一些变化。...通常我们会使用两个属性,一个是DisplayFormulaBar属性,用于设置是否显示/隐藏公式栏;一个是FormulaBarHeight属性,用于设置公式栏的高度。...下面我们列举两个示例来看看VBA是怎么操控公式栏的。 示例1:对指定列自动增加公式栏高度 当用户将当前单元格置于指定列时,公式栏自动增加高度。...例如,当前单元格位于列C时,公式栏会向下扩展,从而显示更多内容;位于其他列时,恢复原高度。...图2 示例2:对指定单元格隐藏公式栏 有时候,我们不想让用户直接看到我们所使用的公式,此时就可以在用户将单元格移到指定单元格时,隐藏公式栏。 例如,当用户将单元格移至列D时,隐藏公式栏。

    2.1K20

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

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

    2.9K10

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

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

    3.3K10

    Excel公式练习64: 获取单元格区域中移除空单元格后的值

    本次的练习是:如下图1所示,列C中有很多空单元格,使用公式将其整理,移除空单元格并将值放置在列D中。 ? 图1 先不看答案,自已动手试一试。...公式 在单元格D2中,输入数组公式: =IFERROR(OFFSET(C2,SMALL(IF((List)>1,ROW(List),""),ROW(E1))-2,0),"") 下拉至单元格出现空为止。...公式中的List为名称,引用列C中的单元格区域C2:C10000。...图4 这样,在单元格D2中的公式最终等价为: OFFSET(C2, 2-2,0) 得到单元格C2中的值。...在单元格D3中的公式最终等价为: OFFSET(C2, 6-2,0) 得到单元格C6中的值。 在单元格D4中的公式最终等价为: OFFSET(C2, 7-2,0) 得到单元格C7中的值。 依此类推。

    4.2K51

    Excel公式技巧56:获取最大值最小值所在的单元格地址

    学习Excel技术,关注微信公众号: excelperfect 在《Excel公式技巧54:在多个工作表中查找最大值最小值》中,我们在MAX/MIN函数中使用多工作表引用来获取最大值/最小值。...在《Excel公式技巧55:查找并获取最大值最小值所在的工作表》中,我们更进一步,获取最大值/最小值所在的工作表名称。本文来讲解如何利用公式获取最大值/最小值在哪个单元格。...示例工作表数据如下图1所示,我们可以使用MAX/MIN函数获取工作表数据的最大值/最小值,并且由于数据较少,可以清楚地看出最大值所在的单元格为B2,最小值位于单元格A2。 ?...图1 可以使用ADDRESS函数来获取单元格地址,但关键是要传递给该函数合适的行列参数。...((A1:D4=C7)*(COLUMN(A1:D4)))),1,1) 得到最大值所在的单元格地址: B2 公式中: ROW(A1:A4) 解析为: {1;2;3;4} ROW(A1:D4) 解析为: {

    13.3K64

    使用VBA进行线性插值

    标签:VBA 如果要在Excel工作表中针对相应数据进行线性插值计算,使用VBA如何实现? 如下图1所示,有3个值,要使用这3个值进行线性插值。 图1 结果如下图2所示。...图2 可以使用下面的VBA代码: Sub LinInterp() Dim rKnown As Range '已知数值的区域 Dim rGap As Range '插值区域 Dim dLow As...Double '最小值 Dim dHigh As Double '最大值 Dim dIncr As Double '增加值 Dim cntGapCells As Long '填充插值的单元格数...Dim iArea As Long '区域数变量 Dim iGap As Long '插值变量 '赋已知数组成的单元格区域给变量 Set rKnown = ActiveSheet.Columns...之所以分享这个示例,主要是其使用了SpecialCells方法来获取相应的单元格组织单元格区域,有兴趣的朋友可以好好体会。 注:本文代码收集自.vbaexpress.com,供参考。

    94510

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

    本文主要讲解设置工作表单元格或单元格区域格式的VBA代码,包括设置字体、数字格式、文本对齐、填充单元格背景色、设置单元格边框等。...使用颜色填充单元格 示例代码: '使用指定颜色填充单元格区域的背景色 With Range("A1:D3").Interior '设置为xlNone则无填充 .Color = vbBlack '-1(最暗...)到1(最亮) .TintAndShade= 0.5 '颜色索引值为0到56 '3是红色,4是绿色,5是蓝色 .ColorIndex = 3 ' End With 效果演示如图2所示。...图3 可以在VBA帮助中查找获取代表线条样式的VBA常量值。...图4 说明:本专题系列大部分内容学习整理自《Dissectand Learn Excel VBA in 24 Hours:Changingworkbook appearance》,仅供学习研究。

    8.6K20

    一个VBA自定义函数,使用文本格式连接唯一值单元格

    标签:VBA实用代码 一个单元格区域内有一组数字,这些数字中存在多个相同的数字,想要将这些数字中的唯一值提取出来并组合成一串数字文本,如下图1所示。...图1 可以使用VBA编写自定义函数来实现,代码如下: Function ConcatenateUnique(ByRef rngRange As Range, _ Optional ByVal...If End If Next rng '返回结果字符串 ConcatenateUnique = strAnswer End Function 这个函数仅将指定单元格区域中的唯一值使用可选的格式字符串连接起来...此函数在每个值之间插入分隔符字符串,默认分隔符设置为” ”。 这段代码来自strugglingtoexcel.com。通常,我们会考虑使用Dictionary对象,在连接符合要求的值之前获取唯一列表。...然而,这段代码另辟蹊径,使用了VBA中的InStr函数,在连接之前检查是否已将值添加到结果中,如果没有则添加。巧妙的实现方法!

    2.3K20

    如何在合并单元格使用公式计算装车时间

    今晚在学员群里看到一个很有挑战性的问题 大概的数据案例如下 第一想法是使用INDIRECT函数,例如第一个合并单元格,可以用下面得出答案 =INDIRECT("C7")-INDIRECT("B2"...合并单元格的实质是什么?...就是把内容(公式,数值等)放在合并单元格的左上角,其他单元格都变成空值 根据这个实质,我们可以对单元格进行统计分组,所以有了辅助列2,需要巧妙的用COUNTA函数 因为合并单元格之间都是空,所以会自动统计合并单元格数量...这里有个小技巧:注意最开始的单元格是固定的,这样下拉会使范围越来越大 好了,我们根据这两列可以求到每个合并单元格最开始的行号和列号了 最开始的行号=第一个合并单元格分组号 最末尾的行号=第一个合并单元格分组号...+组员数-1 使用MATCH函数找到第一个分组号,返回对应的辅助列1的内容,就是合并单元格最开始的行号 在第一个思路的基础上,加上分组组员数量,减1,即得到末尾行号 回到最开始的思路 =INDIRECT

    1.1K10

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

    学习Excel技术,关注微信公众号: excelperfect 如果有一个依赖于一些计算慢的资源的用户定义函数,可能希望该用户定义函数在大多数情况下只返回其占用的单元格中最后一次计算得到的值,并且只偶尔使用计算慢的资源...Application.Caller.Text,则不会获得循环引用,但会检索单元格中显示为字符串的格式化值。...因此,如果单元格被格式化为带有2个小数位的数字,则检索到的值将被截断为2个小数位。...(命令等效函数默认为易失性,但在使用它将前一个值传递给VBA用户定义函数时,通常希望它是非易失性的)。此函数也适用于多单元格数组公式。...小结 有几种方法可以从VBA用户定义函数的最后一次计算中获取先前的值,但最好的解决方案需要使用C++ XLL。

    10.1K20
    领券