返回所选系列的索引

时间:2015-02-13 08:34:26

标签: excel vba indexing charts line

有一种简单的方法可以使用VBA获取Excel图表中所选行的索引吗?我有一个图表,用户选择一个系列。然后宏应该做一些事情。我正在寻找类似idx = Selection.getIndex的内容。

我需要这个idx来调用其他函数,这些函数使用索引来选择特定的系列(例如FullSeriesCollection(idx).DataLabels.labelPos=...

2 个答案:

答案 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) 

Parameter description (the same as BeforeDoubleClick)