前言看到题目,估计大家都笑了,直线有什么好学的,拿起鼠标点两下不就行了么? 在EXCEL中手动画一条线非常简单,连续画100条线累不累呢,如果数据变了,你要再画一遍吗? 带着这些问题我们看一下vba是怎么画线的。 探究在EXCEL中按ALT+F11打开vba编辑器 在代码窗口输入下列代码: Sub 画线() ActiveSheet.Shapes.AddLine 50, 20, 300, 100 End Sub 按F5运行,你的活动窗口就画出一条直线,如下图所示. 画线的命令和参数非常简单,就是通过线段起始点和结束点的坐标确定一条直线.格式为 Activesheet.shapes.addline start_x, start_y, finish_x, finish_y EXCEL以左上角为坐标原点,向左为X轴正方向,向下为Y轴正方向,如下图所示: 想让直线乖乖的听话,首先你要确定端点的坐标,那么端点的坐标与单元格是什么关系呢? 单元格的坐标和尺寸属性如下表所示:
练习 休息一下马上回来: 下面的是一段计划模板,根据开始和结束日期在右面画出相应的线段 首先确定开始日期和结束日期对应的列,公式如下: D1=MATCH(B2,$A$1:$O$1,1) E1=MATCH(C2,$A$1:$O$1,1) 打开vba编辑器来上一段代码: Sub drawline() For i = 2 To 4 Start_x = Cells(i,Cells(i, 4)).Left Start_y = Cells(i,Cells(i, 4)).Top + Rows(i).Height / 2 Finish_x =Cells(i, Cells(i, 5)).Left + Cells(i, Cells(i, 5)).Width Finish_y = Start_y ActiveSheet.Shapes.AddLine(Start_x,Start_y,Finish_x, Finish_y).Select WithSelection.ShapeRange.Line .Weight = 3 .ForeColor.RGB= vbRed End With Next End Sub 按F5运行代码,结果如下: 知识点图形坐标系的认知 代码看不懂没关系,照葫芦画瓢 画线命令: Activesheet.shapes.addline start_x, start_y, finish_x, finish_y 线宽: Selection.ShapeRange.Line.Weight=3 线的颜色: Selection.ShapeRange.Line.ForeColor.RGB = vbRed 这只是图形的入门,思考一下:如果日期栏不是按天而是按周或按月显示,如何去做呢? |
|