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

VBA获取单击超链接的单元格的值

在Excel VBA中,要在单击超链接时获取单元格的值,请按照以下步骤操作:

  1. 首先,在工作表中添加一个超链接。例如,可以在A1单元格中插入一个指向B1单元格的超链接。
  2. 在VBA编辑器中,打开工作表的事件处理程序。可以通过双击工作表选项卡(如“Sheet1”)进入事件处理程序。
  3. 在工作表的事件处理程序中,添加以下代码:
代码语言:javascript
复制
Private Sub Worksheet_FollowHyperlink(ByVal Target As Hyperlink)
    Dim hyperlinkCell As Range
    Dim targetCell As Range
    
    ' 检查超链接是否指向当前工作表的单元格
    If Target.Range.Address = "" Then Exit Sub
    
    Set hyperlinkCell = Target.Range
    Set targetCell = ThisWorkbook.Worksheets(Target.Parent.Name).Range(Target.Address)
    
    ' 在此处处理所需的操作,例如将超链接单元格的值复制到其他单元格
    MsgBox "您单击的超链接单元格 " & hyperlinkCell.Address & " 的值为: " & targetCell.Value
End Sub

这段代码会在单击工作表中的任何超链接时触发Worksheet_FollowHyperlink事件。它会检查超链接是否指向当前工作表的单元格,如果是,则获取目标单元格的值并显示一个消息框。您可以自定义此代码以执行所需的操作,例如将值复制到其他单元格。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

VBA: 获取单元格内超链接文件的绝对路径

文章背景:在工作中,有时为了内容跳转的方便,会在单元格内设置超链接,通过Hyperlinks(1).Address,得到的是超链接文件的相对路径。...有时为了VBA代码的编写方便,需要使用的是链接文件的绝对路径。下面通过编写VBA函数,获取单元格内超链接文件的绝对路径。 1 绝对路径和相对路径 有两种方法指定一个文件路径。...回到VBA,通过ThisWorkbook.Path,可以获取当前工作簿所在工作目录的路径;通过Hyperlinks(1).Address,得到的是基于ThisWorkbook.Path的相对路径;通过ThisWorkbook.Path...2 函数编写 针对单元格内的超链接,本文暂不考虑共享文件夹的情况,链接的文件可以分为以下三种情况: 在同一工作目录内; 在同一个公共盘,不在同一工作目录内; 不在同一公共盘。...如果单元格链接的是本工作簿内的单元格,则Hyperlinks(1).Address得到的是空字符串。

3.5K40

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

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

6.8K20
  • VBA技巧:记住单元格更改之前的值

    标签:VBA,工作表事件 当工作表单元格中的值被修改后,我需要将修改前的值放置到其右侧单元格中。例如,单元格A1中输入有数值1,当我将其内容修改为2之后,之前的数值1被放置到单元格B2中。...Worksheets("Sheet1").Range("B1") = sOldValue Application.EnableEvents = True End If End Sub 这样,当在单元格...A1中重新输入值时,原值会自动放置到单元格B1中。...当一列单元格区域中的值发生改变时,需要将修改之前的值放置到相邻列对应单元格中,例如对于单元格区域A1:A10,其值发生改变时,原来的值会自动放置到单元格区域B1:B10对应的单元格中。...Value = Target.Value Target.Value = sNewValue Application.EnableEvents = True End If End Sub 有兴趣的朋友可以试试看

    37810

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

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

    18610

    Python批量爬虫下载文件——把Excel中的超链接快速变成网址

    1 方法一:单个超链接鼠标点击转换 第一个方法是选中想要把超链接转换成对应网址的单元格,接着双击鼠标左键,然后回车,单元格内容就会自动转换成网址。...第二个方法我尝试下来还是失败了…… 3 方法三:自定义VBA函数转换 第三个方法是自定义VBA函数进行转换。...[2]自定义一个VBA函数GetAdrs。 首先左键单击【开发工具】选项,然后左键单击【代码】功能区中的【Visual Basic编辑器】。...1) GetAdrs = IIf(.Address = "", .SubAddress, .Address) End With End Function [3]用函数GetAdrs获取网址...首先左键单击选中【B2】单元格,键入自定义函数【=GetAdrs(A2)】,按回车键进行计算。将鼠标指针移动至【B2】单元格右下角,当鼠标指针变成【+】号后,长按鼠标左键并向下拖动进行公式填充。

    1.1K20

    VBA中的高级筛选技巧:获取唯一值

    标签:VBA,AdvancedFilter方法 在处理大型数据集时,很可能需要查找并获取唯一值,特别是唯一字符串。...在VBA中,AdvancedFilter方法是处理这种情形的非常强大的一个工具。该方法可以保留原数据,采用基于工作表的条件,可以找到唯一值。下面,将详细介绍如何获取并将唯一值放置在单独的地方。...设置要筛选的单元格区域 AdvancedFilter方法对Range对象进行操作。接通常做法,设置单元格区域,但要注意,VBA始终将第一行视为包含标题的行。...如果数据没有标题,即第一个单元格是常规值,则第一个值可能会在唯一值列表中出现两次。 通常,我们只是在一列中查找唯一值。...如果输出区域太小,无法包含所有结果,VBA将溢出该区域。这意味着无法限制输出,因此要选择一个没有值或可以覆盖原有值的列。

    8.6K10

    VBA小技巧07: 获取想要颜色的RGB值

    在某些情况下,我们在编写代码时需要设置颜色,例如,下面的代码填充当前单元格背景色为红色: ActiveCell.Interior.Color= RGB(255, 0, 0) 那么,如何直观地得到我们想要颜色的...当然,我们可以使用代码一个一个值地试,但范围太大,也太慢了,没有必要。实际上,可以充分利用Excel给我们提供的功能来获取RGB值。...在任意单元格中单击鼠标右键,在弹出的MINI工具栏中单击“填充颜色”右侧下拉箭头,选择“其他颜色”,如下图1所示。 ?...图1 在弹击的“颜色”对话框中,选择“自定义”选项卡,在“颜色”区域选取我们想要的颜色区域,单击其右侧的颜色条调节深浅,至合适的颜色后,左下方会显示该颜色的RGB值,右下方显示该颜色的效果,如下图2所示...图2 可以记下其RGB值,然后运用到VBA代码中。既直观又方便!

    3K40

    VBA实战技巧08: 鼠标悬停在超链接公式上时运行自定义函数

    本文介绍的技巧来自于myspreadsheetlab.com,这个技巧很有趣,当鼠标悬停在超链接公式上时会运行使用VBA自定义的函数,如下图1所示。 ?...这个名称为“XIndex”的单元格就是单元格K98。 因此,当我们将鼠标悬停在公式单元格K9上时,会将单元格K100中的值传递给RolloverSquare函数。...在函数中,将该值与单元格K98中的值加上1的结果比较,如果两者不相等,则将K98中的值修改为K100中的值加1。...简单地说,就是当鼠标悬停在公式单元格K9上时,会比较单元格K98和K100中的值,如果K100中的值不等于K98+1,则单元格K98=K100+1。 其中间运行过程信息如下图2所示。 ?...图4 蓝色区域中使用了我们在上文中的超链接公式。

    1.5K20

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

    本次的练习是:如下图1所示,列C中有很多空单元格,使用公式将其整理,移除空单元格并将值放置在列D中。 ? 图1 先不看答案,自已动手试一试。...重点看看: SMALL(IF((List)>1,ROW(List),""),ROW(E1))-2 我们要从IF((List)>1,ROW(List),"")中获取第ROW(E1)小的值,而ROW(E1)...””;13;14;15;…},1) 得到: 2 将公式向下拉时,ROW(E1)将自动更新为ROW(E2)、ROW(E3)、…等,即返回值2、3、…,获取数组中第2小的值、第3小的值、… 相应地在工作表中演示如下图...图4 这样,在单元格D2中的公式最终等价为: OFFSET(C2, 2-2,0) 得到单元格C2中的值。...在单元格D3中的公式最终等价为: OFFSET(C2, 6-2,0) 得到单元格C6中的值。 在单元格D4中的公式最终等价为: OFFSET(C2, 7-2,0) 得到单元格C7中的值。 依此类推。

    3.1K51

    VBA专题13:引用单元格单元格区域的方法

    在VBA中,可以通过多种不同的方式来引用工作表中的单元格/单元格区域。下面是一些引用方法的汇总。 Range(“D1”) 引用单元格D1。 Range(“D” & i) 引用列D中行号为i的单元格。...Range(“RangeName”) 引用名称为“RangeName”的单元格区域。 Cells(1,4) 引用第1行第4列的单元格,即单元格D1。 Cells 引用工作表中所有的单元格。...引用连续单元格区域中最底部的单元格(即该单元格下方的单元格为空)。还可以使用xlUP、xlLeft和xlRight来引用相应的单元格。...Range(“A1”).EntireColumn 引用起始单元格所在的整列。如果选择了多个单元格,则引用这些单元格所在的多列。 Range(“A1”).EntireRow 引用起始单元格所在的整行。...引用目标单元格的所有从属单元格,包括从属单元格的从属单元格。如果工作表中没有从属单元格可用则返回错误。 Range(“A1”,”D1”) 引用单元格区域A1:D1。

    3.9K20

    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) 解析为: {

    11.1K64

    Word VBA技术:将文档中的超链接转换为普通文本(取消超链接)

    标签:Word VBA 通常,当我们在文档中键入超链接形式的文字并按回车键时,Word会自动识别并添加超链接。当然,你可以设置Word选项来阻止自动转换功能。...具体设置方法如下: 单击“文件——选项”,在出现的“Word选项”窗口中选择左侧的“校对”选项卡,在右侧单击“自动更正选项按钮”,在出现的“自动更正”窗口中选择“键入时自动套用格式”,取消勾选其中的“Internet...及网络路径替换为超链接”前的复选框。...,但页码的超链接仍保留。...Word VBA文章,是自己边学习边分享的,有用无用看个人,希望大家不要发表一些不好的评论,这些评论我不会通过的!

    3K20

    运行Excel VBA的15种方法2

    标签:VBA 本文接上一篇:运行Excel VBA的15种方法1 方法8:自定义功能区 可以自定义功能区,将宏代码关联到功能区选项卡组中。这种方法尤其适合于组织布置许多自定义宏的运行。...图19 方法9:从VBE的运行菜单中运行VBA 在VBE中,首先将光标置于要运行的过程代码中,然后单击顶部菜单“运行——运行子过程/用户窗体”,如下图20所示。...图20 方法10:从VBE工具栏中运行VBA 在VBE中,首先将光标置于要运行的过程代码中,然后单击顶部调试工具栏中的“运行——运行子过程/用户窗体”按钮,如下图21所示。...例如下图22所示的代码。 图22 这段代码在工作表Sheet1代码模块中,当工作表Sheet1中的单元格A1发生变化会自动调用testVBA过程。...方法14:从超链接中运行VBA 单击超链接时触发宏运行,如下图23所示。 图23 很特别! 方法15:从工作簿事件中调用VBA过程 基于工作簿事件,例如打开或关闭工作簿时自动运行宏。

    54840

    使用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.5K30
    领券