有一种简单的方法可以使用VBA获取Excel图表中所选行的索引吗?我有一个图表,用户选择一个系列。然后宏应该做一些事情。我正在寻找类似idx = Selection.getIndex
的内容。
我需要这个idx来调用其他函数,这些函数使用索引来选择特定的系列(例如FullSeriesCollection(idx).DataLabels.labelPos=...
)
答案 0 :(得分:2)
有三个想法:
第一次使用对象变量而不是索引引用:
Dim SER As Series
Set SER = Selection
SER.anyproperty.anymethod... 'do your action here
第二次使用绘图顺序获取...索引(但不确定这是否总是匹配)?
Dim inxSer As Integer
inxSer = Selection.PlotOrder
第3次 - 阅读系列公式的最后一个参数
Dim inxFromFormula As Integer
Dim tmpSerFormula As String
tmpSerFormula = Selection.Formula
tmpSerFormula = Mid(tmpSerFormula, InStrRev(tmpSerFormula, ",") + 1)
inxFromFormula = Left(tmpSerFormula, Len(tmpSerFormula) - 1)
答案 1 :(得分:1)
您可以利用图表对象事件来实现这一目标。如果图表嵌入在工作表中,则需要首先将其声明为“WithEvents”变量,如下所述: Using Events with Embedded Charts
之后,您可以使用以下参数定义SeriesChange处理程序:
Private Sub myChartClass_SeriesChange(ByVal SeriesIndex As Long, ByVal PointIndex As Long)
End Sub
编辑:当用户更改点值时会触发上述事件,您应该使用Select事件。
myChartClass_Select(ByVal ElementID As Long, ByVal Arg1 As Long, ByVal Arg2 As Long)