The Issue
If you have XY data from two different times, or under two different sets of conditions, you can connect points of one series (one time or condition) to another (another time or condition), to help show how the data evolves. For example, here are two series of data that I might want to connect together.
data:image/s3,"s3://crabby-images/4298b/4298be2240717fa3fbe0c655b168d982d6171ec1" alt="Series A and Series B to be connected by line segments"
Several years ago I wrote Connect Two XY Series, which showed how to connect the points of one series to the corresponding points of another series. This approach used a third series with data from Series A and Series B, interwoven with blank cells.
data:image/s3,"s3://crabby-images/bea47/bea47ef74651321b15c7ead475e38a7fe5c2bdc5" alt="Series A and Series B connected by line segments"
I followed this up with Connect Two XY Series with Arrows (VBA), which showed how to connect the two series with arrows. In Excel 2003 and earlier, you had to use VBA to draw the arrows, and this article provided the VBA (and it’s reproduced below).
data:image/s3,"s3://crabby-images/85774/8577442cd11d3e2d21d6a04147cb0deb6187d160" alt="Series A and Series B connected by arrows, using VBA"
This works nicely enough, but the arrows are not tied to the points, but only to the original positions of the points within the chart. So if you change the axes in the chart …
data:image/s3,"s3://crabby-images/d70c6/d70c6035c7360ee5825444159ad8e79986e702c6" alt="Series A and Series B no longer connected by arrows"
… or change the size or shape of the chart …
data:image/s3,"s3://crabby-images/d8a59/d8a59d48b013489a298d17b7f3cfe37f21e51a9d" alt="Series A and Series B no longer connected by arrows"
… the arrows no longer match up to the points.
You could always delete the misaligned arrows and rerun the VBA procedure, but what a pain.
I hinted in this second article that you could connect the points with arrows in Excel 2007, without using VBA but instead by formatting the third series that connected the first two series. But I never explained how. This article fills the gap.
Connect Two Series with Arrows, Without VBA
You need to keep the original Series A and B data in place, so you can still easily plot the original points. You need to get data into a new range, interweaving Series A with Series B.
Set Up The Data – Approach 1
To get the data into this alternating arrangement, start by pasting the data from Series A into a new range, then paste the data from Series B below it. Enter a set of index numbers into a column adjacent to this combined data, from 1 to the number of points in Series A, and from 1 to the number of points in Series B (which should be the same number of points). This is the first data block below.
Select the data, and sort by the column of digits you just entered. The data now has alternating Series A and B data (below right).
data:image/s3,"s3://crabby-images/52133/52133f489ad83eddea210b85c12a9d67d2ca3e47" alt="Sorted Data for Series A and B"
Select the data and create a chart, or add it as a new series to the chart of Series A and Series B.
data:image/s3,"s3://crabby-images/f3fc8/f3fc8c4ca24ed68bedb89d17bc55433344f29dc8" alt="Series A and Series B connected with lines, but needing gaps at alternating segments"
Hmmm, that’s almost what I want. But there are too many line segments. We need to eliminate half of them, shown as dashed lines below.
data:image/s3,"s3://crabby-images/9acd6/9acd60edfcf9c199818ab4940886a8628edef473" alt="Series A and Series B connected with lines, showing where gaps are needed"
We could format alternating line segments to be drawn with no line, but that’s mighty tedious after the first or second segment. Speaking from experience, because I had to format the dashed lines in the chart above, segment by segment.
As I’ve written about in Mind the Gap – Charting Empty Cells, the way we get a gap between points in a chart is to have a gap in the data, that is, blank cells between the points.
So let’s alter our protocol above, so that we start with the Series A data, then the Series B data below that, then an equal number of blank rows at the bottom, and include our index column (below left).
Sort by the index column, to get Series A and B data pairs, separated by blanks (below right).
data:image/s3,"s3://crabby-images/392b7/392b7fc864e666ab460a5e13d673630d0a575f8b" alt="Sorted Data for Series A and B and blanks"
Now when we plot this data, we connect appropriate pairs of points, with gaps between points we do not want to connect.
data:image/s3,"s3://crabby-images/590fd/590fdd7a2144ff92e44c6f618e849eceb05c352e" alt="Series A and Series B connected with lines, with gaps"
Set Up The Data – Approach 2
Above we produced our data range by copying the data into a new range, and sorting the data appropriately. We could instead have stretched out the data first, then copied and pasted using the Skip Blanks option.
Here’s a copy of the Series A and B data, with two rows inserted between each point.
data:image/s3,"s3://crabby-images/2cced/2cced74b9cf5ffbe91a4d0dcd15bb4daa1481518" alt="Series A and B data, expanded with blank rows"
Copy the expanded Series A data, select the first cell of a new range, …
data:image/s3,"s3://crabby-images/31f85/31f851ee5f73b268d3f5cc80dfdaf3cf02a92f5e" alt="Series A data copied"
… then paste.
data:image/s3,"s3://crabby-images/e03d1/e03d10849ce7522cb9dcc4c0a1ef43e88b1a37d2" alt="Series A data pasted"
Now copy the Series B data, select the cell below the first Series A point, …
data:image/s3,"s3://crabby-images/2dec0/2dec0bfb6ddc9ad055670f21bf1a3e2dfad28c4d" alt="Series B data copied"
… and use Paste Special, and check the Skip Blanks option near the bottom of the dialog. Skip Blanks prevents blanks in the copied range from being pasted over data in the target range, so the Series A data is preserved.
data:image/s3,"s3://crabby-images/b280f/b280fc29984ee8532a18310d800975f946289a74" alt="Series B data pasted, skipping blanks to preserve Series A data"
Now the data is ready to plot.
Make the Chart
Select the Series A data (shaded blue below), and create an XY Scatter chart. Then copy the Series B data (shaded orange), select the chart, and use Paste Special to add the data as a new series, with series in columns, Y values in the first column, series names in the first row. The resulting chart is shown below right.
data:image/s3,"s3://crabby-images/abafc/abafc3224b993bdc7d6cf8a4b0688704aa251e44" alt="Series A and Series B, to be connected with arrows"
Now copy the A-B Interwoven data (below left), select the chart, and again use Paste Special to add this data as a new series, with series in columns, Y values in the first column, series names in the first row, to produce the chart shown below right. (You may have to format the new series to show lines and no markers)
data:image/s3,"s3://crabby-images/b4923/b492383db98bd20910b1f5a706a15ee745939385" alt="Series A and Series B connected with line segments"
Now you need to format the line segments of the new series. Select the series and press Ctrl+1 (numeral one) to open the Format Data Series task pane or dialog. Click the End Arrow Type dropdown, and select the desired arrow type. The options include three arrowheads, a circle, a diamond, and a plain line.
data:image/s3,"s3://crabby-images/8e901/8e9014f868c618103141a0dc1ca8278844e93aa8" alt="Format Data Series Lines - End Arrow Type"
Now click the End Arrow Size dropdown, and choose an appropriate size for the arrowhead. There are combinations of three arrowhead lengths and widths.
data:image/s3,"s3://crabby-images/7a375/7a375a7d73e824b983667b36f4d62e73131d8979" alt="Format Data Series Lines - End Arrow Size"
Now the line segments have been transformed into arrows.
data:image/s3,"s3://crabby-images/213db/213dba763d38c42896c50927a116af676ddf8239" alt="Series A and Series B connected with arrows"
Unlike the VBA approach of the old tutorial, the arrows are tied to the points in Series A and Series B. So if you change the axes in the chart …
data:image/s3,"s3://crabby-images/0c65f/0c65f1b4f0aa22222f436a81cb16271c35b3c403" alt="Series A and Series B still connected by arrows"
… or change the size or shape of the chart …
data:image/s3,"s3://crabby-images/a5528/a5528077312fd6b36956dc0390cf1c39616fae7c" alt="Series A and Series B still connected by arrows"
… the arrows still match up to the points.
The VBA
You don’t need to use VBA to connect points with arrows, but it is a good sample application of VBA to your charts. Just so you don’t have to go back to the earlier post, here is the VBA Procedure that connects the points with line segments with arrowheads.
Sub ConnectTwoXYSeriesWithArrows()
Dim myCht As Chart
Dim mySrs1 As Series
Dim mySrs2 As Series
Dim nPts As Long, iPts As Long
Dim myBuilder As FreeformBuilder
Dim myShape As Shape
Dim iShp As Long
Dim Xnode1 As Double, Ynode1 As Double
Dim Xnode2 As Double, Ynode2 As Double
Dim Xmin As Double, Xmax As Double
Dim Ymin As Double, Ymax As Double
Dim Xleft As Double, Ytop As Double
Dim Xwidth As Double, Yheight As Double
' a chart with at least two series must be selected
If ActiveChart Is Nothing Then
GoTo ExitSub
End If
If ActiveChart.SeriesCollection.Count < 2 Then
GoTo ExitSub
End If
Set myCht = ActiveChart
Set mySrs1 = myCht.SeriesCollection(1)
Set mySrs2 = myCht.SeriesCollection(2)
nPts = mySrs1.Points.Count
' two series must have matching numbers of points
If mySrs2.Points.Count <> nPts Then
GoTo ExitSub
End If
' remove any old connecting arrows
For iShp = myCht.Shapes.Count To 1 Step -1
If Left(myCht.Shapes(iShp).Name, 12) = "ArrowSegment" Then
myCht.Shapes(iShp).Delete
End If
Next
Xleft = myCht.PlotArea.InsideLeft
Xwidth = myCht.PlotArea.InsideWidth
Ytop = myCht.PlotArea.InsideTop
Yheight = myCht.PlotArea.InsideHeight
Xmin = myCht.Axes(xlCategory).MinimumScale
Xmax = myCht.Axes(xlCategory).MaximumScale
Ymin = myCht.Axes(xlValue).MinimumScale
Ymax = myCht.Axes(xlValue).MaximumScale
For iPts = 1 To nPts
' first point
Xnode1 = Xleft + (mySrs1.XValues(iPts) - Xmin) * Xwidth / (Xmax - Xmin)
Ynode1 = Ytop + (Ymax - mySrs1.Values(iPts)) * Yheight / (Ymax - Ymin)
' second point
Xnode2 = Xleft + (mySrs2.XValues(iPts) - Xmin) * Xwidth / (Xmax - Xmin)
Ynode2 = Ytop + (Ymax - mySrs2.Values(iPts)) * Yheight / (Ymax - Ymin)
' draw connecting line
Set myShape = myCht.Shapes.AddLine(Xnode1, Ynode1, Xnode2, Ynode2)
' name and format shape as arrowhead
With myShape
.Name = "ArrowSegment" & CStr(iPts)
With .Line
' USE YOUR FAVORITE FORMATS HERE
.ForeColor.ObjectThemeColor = msoThemeAccent3
.ForeColor.Brightness = -0.25
.Weight = 1.5
.EndArrowheadLength = msoArrowheadLong
.EndArrowheadWidth = msoArrowheadWidthMedium
.EndArrowheadStyle = msoArrowheadTriangle
End With
End With
Next
ExitSub:
End Sub