1、1Shape(图形) 、Chart(图表)对象在工作表中添加图形如果需要在工作表中添加图形对象,可以使用 AddShape 方法,如下面的代码所示。#001 Sub AddShape()#002 Dim myShape As Shape#003 On Error Resume Next#004 Sheet1.Shapes(“myShape“).Delete#005 Set myShape = Sheet1.Shapes.AddShape(msoShapeRectangle, 40, 120, 280, 30)#006 With myShape#007 .Name = “myShape“#008
2、 With .TextFrame.Characters#009 .Text = “单击将选择 Sheet2!“#010 With .Font#011 .Name = “华文行楷“#012 .FontStyle = “常规“#013 .Size = 22#014 .ColorIndex = 7#015 End With#016 End With#017 With .TextFrame #018 .HorizontalAlignment = -4108#019 .VerticalAlignment = -4108#020 End With#021 .Placement = 3#022 End Wi
3、th#023 myShape.Select#024 With Selection.ShapeRange#025 With .Line#026 .Weight = 1#027 .DashStyle = msoLineSolid2#028 .Style = msoLineSingle#029 .Transparency = 0#030 .Visible = msoTrue#031 .ForeColor.SchemeColor = 40#032 .BackColor.RGB = RGB(255, 255, 255)#033 End With#034 With .Fill#035 .Transpare
4、ncy = 0#036 .Visible = msoTrue#037 .ForeColor.SchemeColor = 41#038 .OneColorGradient 1, 4, 0.23#039 End With#040 End With#041 Sheet1.Range(“A1“).Select#042 Sheet1.Hyperlinks.Add Anchor:=myShape, Address:=“, _#043 SubAddress:=“Sheet2!A1“, ScreenTip:=“选择 Sheet2!“#044 Set myShape = Nothing#045 End Sub代
5、码解析:AddShape 过程在工作表中添加一个矩形并设置其外观等属性。第 2 行代码声明变量 myShape 的对象类型。第 3、4 行代码删除可能存在的名称为“myShape”的图形对象。第 5 行代码使用 AddShape 方法在工作表中添加一个矩形。当该方法应用于 Shapes对象时,返回一个 Shape 对象,该对象代表工作表中的新自选图形,语法如下:expression.AddShape(Type, Left, Top, Width, Height)参数 expression 是必需的,返回一个 Shapes 对象。参数 Type 是必需的,指定要创建的自选图形的类型。参数 Lef
6、t 和 Top 是必需的,以磅为单位给出自选图形边框左上角的位置。参数 Width 和 Height 是必需的,以磅为单位给出自选图形边框的宽度和高度。第 7 行代码将新建图形命名为“myShape” ,向 Shapes 集合添加新的图形时,将对新添加的图形赋以默认的名称,若要为图形指定更有意义的名称,可指定其 Name 属性。第 8 行到第 16 行代码为矩形添加文字,并设定其格式。3其中第 8 行代码使用 TextFrame 属性和 Characters 方法返回该矩形的字符区域。应用于 Shape 对象的 TextFrame 属性返回一个 TextFrame 对象,该对象包含指定图形对象
7、的对齐和定位属性;Characters 方法返回一个 Characters 对象,该对象代表某个图形的文本框中的字符区域,语法如下:expression.Characters(Start, Length)参数 expression 是必需的,返回一个指定文本框内 Characters 对象的表达式。参数 Start 是可选的,表示将要返回的第一个字符,如果此参数设置为 1 或被忽略,则 Characters 方法会返回以第一个字符为起始字符的字符区域。参数 Length 是可选的,表示要返回的字符个数。如果此参数被忽略,则 Characters方法会返回该字符串的剩余部分(由 Start 参数
8、指定的字符以后的所有字符) 。第 9 行代码为矩形添加文字,应用于 Characters 对象的 Text 属性返回或设置对象的文本,为可读写的 String 类型。第 10 行到第 15 行代码设置矩形中文字的属性,应用于 Characters 对象 Font 属性返回一个 Font 对象,该对象代表指定对象的字体属性(字体名称、字体大小、字体颜色等) ,第 11 行代码设置字体名称,第 12 行代码设置字体样式,第 13 行代码设置字体大小,第14 行代码颜色。第 17 行到第 20 行代码设定矩形中文字的对齐方式。应用于 TextFrame 对象的HorizontalAlignment
9、属性返回或设置指定对象的水平对齐方式,可为 表格 53-1 所示的XlHAlign 常量之一。常量 值 描述xlHAlignCenter -4108 居中xlHAlignCenterAcrossSelection 7 靠左xlHAlignDistributed -4117 分散对齐xlHAlignFill 5 分散对齐xlHAlignGeneral 1 靠左xlHAlignJustify -4130 两端对齐xlHAlignLeft -4131 靠左xlHAlignRight -4152 靠右表格 1-1 HorizontalAlignment 属性的 XlHAlign 常量应用于 TextF
10、rame 对象的 VerticalAlignment 属性返回或设置指定对象的垂直对齐方式,可为 表格 53-2 所示的 XlHAlign 常量之一。常量 值 描述xlVAlignCenter -4108 居中xlVAlignJustify -4130 两端对齐4xlVAlignBottom -4107 靠下xlVAlignDistributed -4117 分散对齐xlVAlignTop -4160 靠上表格 1-2 VerticalAlignment 属性的 XlHAlign 常量第 21 行代码设置矩形大小和位置不随单元格而变,应用于 Shape 对象的 Placement属性返回或设置
11、对象与所在的单元格之间的附属关系,可为 表格 53-3 所示的XlPlacement 常量之一。常量 值 描述xlFreeFloating 3 大小、位置均固定xlMove 2 大小固定、位置随单元格而变xlMoveAndSize 1 大小、位置随单元格而变表格 1-3 XlPlacement 常量第 24 行到第 32 行代码设置矩形的边框线条格式,应用于 ShapeRange 集合的 Line属性返回一个 LineFormat 对象,该对象包含指定图形的线条格式属性。其中第 26 行代码设置矩形线条粗细,第 27 行代码设置矩形线条的虚线样式,第 28行代码设置矩形填充的透明度,第 29
12、行代码设置矩形为可见,第 30 行代码设置矩形的前景色,第 31 行代码设置矩形填充背景的颜色。第 33 行到第 38 行代码设置矩形的内部填充格式,应用于 ShapeRange 集合的 Fill 属性返回 FillFormat 对象,该对象包含指定的图表或图形的填充格式属性。其中第 35 行代码设置矩形内部的透明度,第 36 行代码设置矩形内部为可见,第 37行代码设置矩形内部的前景色,第 38 行代码将矩形内部指定填充设为单色渐变,应用于 FillFormat 对象的 OneColorGradient 方法将指定填充设为单色渐变,语法如下:expression.OneColorGradie
13、nt(Style, Variant, Degree)其中参数 Style 是必需的,底纹样式,可为 表格 54-1 所示的 MsoGradientStyle 常量之一。常量 值 描述msoGradientDiagonalDown 4 斜下msoGradientDiagonalUp 3 斜上msoGradientFromCenter 7 无msoGradientFromCorner 5 角部幅射msoGradientFromTitle 6 中心幅射msoGradientHorizontal 1 水平msoGradientMixed -2 无5msoGradientVertical 2 垂直表格
14、1-4 MsoGradientStyle 常量参数 Variant 是必需的,渐变变量。取值范围为 1 到 4 之间,分别与“填充效果” 对话框中“ 渐变 ”选项卡的四个渐变变量相对应。如果 GradientStyle 设为 msoGradientFromCenter,则 Variant 参数只能设为 1 或 2。参数 Degree 是必需的,灰度。取值范围为 0.0(表示最深)到 1.0(表示最浅)之间。第 42、43 行代码为矩形对象添加超链接,应用于 Hyperlinks 对象的 Add 方法向指定的区域或图形添加超链接,语法如下:expression.Add(Anchor, Addre
15、ss, SubAddress, ScreenTip, TextToDisplay)参数 expression 是必需的,返回一个 Hyperlinks 对象。参数 Anchor 是必需的,超链接的位置。可为 Range 对象或 Shape 对象。参数 Address 是必需的,超链接的地址。参数 SubAddress 是必需的,超链接的子地址。参数 ScreenTip 是可选的,当鼠标指针停留在超链接上时所显示的屏幕提示。参数 TextToDisplay 是可选的,要显示的超链接的文本。运行 AddShape 过程结果如 图 53-1 所示。图 1-1 在工作表中添加图形技巧 1 导出工作表中
16、的图片6有时需要将工作表中的图形对象保存为单独的图像文件,可以使用 Export 方法将工作表中的图片以文件形式导出,如下面的代码所示。#001 Sub ExportShp()#002 Dim Shp As Shape#003 Dim FileName As String#004 For Each Shp In Sheet1.Shapes#005 If Shp.Type = msoPicture Then#006 FileName = ThisWorkbook.Path & “ & Shp.Name & “.gif“#007 Shp.Copy#008 With Sheet1.ChartObje
17、cts.Add(0, 0, Shp.Width + 28, Shp.Height + 30).Chart#009 .Paste#010 .Export FileName, “gif“#011 .Parent.Delete#012 End With#013 End If#014 Next#015 End Sub代码解析:ExportShp 过程将 Sheet1 工作表的所有图片以文件形式导出到同一目录中。第 4 行代码使用 For Each.Next 语句遍历 Sheet1 工作表中的所有图形。第 5 行代码判断图形的类型是否为图片,应用于 Shape 对象的 Type 属性返回或设置图形类型,
18、可以为 表格 54-1 所示的 MsoShapeType 常量之一。常量 值 说明msoShapeTypeMixed -2 混合型图形msoAutoShape 1 自选图形msoCallout 2 没有边框线的标注msoChart 3 图表msoComment 4 批注msoFreeform 5 任意多边形msoGroup 6 图形组合msoFormControl 8 窗体控件msoLine 9 线条7msoLinkedOLEObject 10 链接式或内嵌 OLE 对象msoLinkedPicture 11 剪贴画或图片msoOLEControlObject 12 ActiveX 控件mso
19、Picture 13 图片msoTextEffect 15 艺术字msoTextBox 17 文本框msoDiagram 21 组织结构图或其他图示表格 1-1 MsoShapeType 常量第 6 行代码使用字符串变量 FileName 记录需导出图形的路径和名称。第 7 行代码复制图形,应用于 Shape 对象的 Copy 方法将对象复制到剪贴板。第 8 行代码使用 Add 方法在工作表中添加一个图表,应用于 ChartObjects 对象的Add 方法创建新的嵌入图表,语法如下:expression.Add(Left, Top, Width, Height)参数 expression 是
20、必需的,返回一个 ChartObjects 对象。参数 Left、参数 Top 是必需的,以磅为单位给出新对象的初始坐标,该坐标是相对于工作表上单元格 A1 的左上角或图表的左上角的坐标。参数 Width、参数 Height 是必需的,以磅为单位给出新对象的初始大小。第 9 行代码使用 Paste 方法将图形粘贴到新的嵌入图表中,应用于 Chart 对象的Paste 方法将剪贴板中的图表数据粘贴到指定的图表中,语法如下:expression.Paste(Type)参数 expression 是必需的,返回一个 Chart 对象。参数 Type 是可选的的,如果剪贴板中有图表,本参数指定要粘贴的
21、图表信息。可为以下 XlPasteType 常量之一: xlFormats、xlFormulas 或 xlAll。默认值为 xlAll,如果剪贴板中是数据不是图表,则不能使用本参数。第 10 行代码使用 Export 方法将图表导出到同一目录中,应用于 Chart 对象的 Export方法以图形格式导出图表,语法如下:expression.Export(Filename, FilterName, Interactive)其中参数 Filename 是必需的,被导出的文件的名称。第 10 行代码删除新建的图表。因为 Chart 对象是不能使用 Delete 方法直接删除的,应先使用 Parent
22、 属性返回指定对象的父对象,然后使用 Delete 方法删除。8技巧 2 在工作表中添加艺术字在工作表中插入艺术字,可以使用 AddTextEffect 方法,如下面的代码所示。#001 Sub TextEffect()#002 Dim myShape As Shape#003 On Error Resume Next#004 Sheet1.Shapes(“myShape“).Delete#005 Set myShape = Sheet1.Shapes.AddTextEffect _#006 (PresetTextEffect:=msoTextEffect15, _#007 Text:=“我爱
23、 Excel Home“, FontName:=“宋体“, FontSize:=36, _#008 FontBold:=msoFalse, FontItalic:=msoFalse, _#009 Left:=100, Top:=100)#010 With myShape#011 .Name = “myShape“#012 With .Fill#013 .Solid#014 .ForeColor.SchemeColor = 55#015 .Transparency = 0#016 End With#017 With .Line#018 .Weight = 1.5#019 .DashStyle =
24、 msoLineSolid#020 .Style = msoLineSingle#021 .Transparency = 0#022 .ForeColor.SchemeColor = 12#023 .BackColor.RGB = RGB(255, 255, 255)#024 End With#025 End With#026 Set myShape = Nothing#027 End Sub代码解析:9TextEffect 过程在工作表中插入艺术字并设置其格式。第 3、4 行代码删除工作表中可能存在的艺术字,以免重复添加。第 5 行到第 9 行代码使用 AddTextEffect 方法在工作
25、表中插入艺术字,AddTextEffect方法创建艺术字对象。返回一个 Shape 对象,该对象代表新建的艺术字对象,语法如下:expression.AddTextEffect(PresetTextEffect, Text, FontName, FontSize, FontBold, FontItalic, Left, Top)参数 expression 是必需的,返回一个 Shapes 对象。参数 PresetTextEffect 是必需的,艺术字预置文本效果,可为 MsoPresetTextEffect 常量之一,等同于在工作表中插入艺术字时的样式选项卡,如 图 55-1 所示。图 2-1
26、 艺术字样式参数 Text 是必需的,艺术字对象中的文字。参数 FontName 是必需的,艺术字对象中所用的字体名称。参数 FontSize 是必需的,以磅为单位给出艺术字对象中所用的字体大小。参数 FontBold 是必需的,在艺术字中要加粗的字体。参数 FontItalic 是必需的,在艺术字中要倾斜的字体。参数 Left 和参数 Top 是必需的,相对于文档的左上角、顶部,以磅为单位给出艺术字对象边框左上角的位置。第 11 行代码将艺术字对象重命名为“myShape” 。第 12 行到第 16 行代码设置艺术字对象的填充格式。其中第 13 行代码将填充格式设置为均一的颜色,应用于 Fi
27、llFormat 对象的 Solid 方法将指定的填充格式设置为均一的颜色,可用本方法将带有渐进色、纹理、图案或背景的填充格式转换为单色的填充格式。第14 行代码设置填充的颜色。第 15 行代码设置填充的透明度。10第 17 行到第 24 行代码设置艺术字对象的线条格式属性。其中第 18 行代码设置线条粗细,第 19 行代码设置线条虚线样式,第 20 行代码设置线条区域的样式,第 21 行代码设置线条的透明度,第 22 行代码设置前景色,第 23 行代码设置填充背景的颜色。运行 TextEffect 过程工作表中如 图 55-2 所示。图 2-2 工作表中插入艺术字技巧 3 遍历工作表中的图形
28、工作表中的多个图形,如果使用系统缺省名称,如“文本框 1”、 “文本框 2”这样前面是固定的字符串,后面是序号的,可以使用 For.Next 语句遍历图形,如下面的代码所示。#001 Sub ErgShapes_1()#002 Dim i As Integer#003 For i = 1 To 4#004 Sheet1.Shapes(“文本框 “ & i).TextFrame.Characters.Text = “#005 Next#006 End Sub代码解析:ErgShapes_1 过程清除工作表中四个图形文本框中的文字。第 3 行到第 5 行代码,使用 Shapes 属性在工作表上的三
29、个图形文本框中循环。Shapes 属性返回 Shapes 对象,代表工作表或图形工作表上的所有图形,可以使用11Shapes(index)返回单个的 Shape 对象,其中 index 是图形的名称或索引号。返回单个的 Shape 对象后使用 TextFrame 属性和 Characters 方法清除文本框中的字符,关于 Shape 对象的 TextFrame 属性和 Characters 方法请参阅 0。如果图形的名称没有规律,可以使用 For Each.Next 语句循环遍历所有图形,根据Type 属性返回的图形类型进行相应的操作,如下面的代码所示。#001 Sub ErgShapes_2
30、()#002 Dim myShape As Shape#003 Dim i As Integer#004 i = 1#005 For Each myShape In Sheet1.Shapes#006 If myShape.Type = msoTextBox Then#007 myShape.TextFrame.Characters.Text = “这是第“ & i & “个文本框“#008 i = i + 1#009 End If#010 Next#011 End Sub代码解析:ErgShapes_2 过程在工作表中的所有图形文本框中写入文本。第 5 行代码使用 For Each.Next
31、 语句循环遍历工作表中所有的图形对象。第 6 行到第 9 行代码如果图形对象是文本框则在文本框中写入文本。其中第 6 行代码根据 Type 属性判断图形对象是否为文本框,应用于 Shape 对象的 Type 属性返回或设置图形类型,MsoShapeType 类型,请参阅 表格 1-1 。第 7 行代码根据返回的 Type 属性值在所有的文本框内写入相应的文本,如 图 56-1 所示。12图 3-1 遍历所有的文本框技巧 4 移动、旋转图片工作表中的图片可以移动、旋转,如下面的代码所示。#001 Sub MoveShape()#002 Dim i As Long#003 Dim j As Lon
32、g#004 With Sheet1.Shapes(1)#005 For i = 1 To 3000 Step 5#006 .Top = Sin(i * (3.1416 / 180) * 100 + 100#007 .Left = Cos(i * (3.1416 / 180) * 100 + 100#008 .Fill.ForeColor.RGB = i * 100#009 For j = 1 To 10#010 .IncrementRotation -2#011 DoEvents#012 Next#013 Next#014 End With#015 End Sub代码解析:MoveShape
33、过程移动、旋转工作表中的图片并不断改变其填充的前景色。第 6 行代码设置图片的 Top 属性值,应用于 Shape 对象的 Top 属性设置图形的顶端到工作表顶端的距离。在循环的过程中使用 Sin 函数将 Top 属性值设置为一个圆形的弧度值。Sin 函数返回指定参数的正弦值,语法如下:Sin(number)参数 number 表示一个以弧度为单位的角。Sin 函数取一角度为参数值,并返回角的对边长度除以斜边长度的比值,将角度除以180 后即能角度转换为弧度。13第 7 行代码设置图片的 Left 属性值,应用于 Shape 对象的 Left 属性设置图形从左边界至 A 列左边界(在工作表中)
34、或图表区左边界(在图表工作表中)的距离。在循环的过程中使用 Cos 函数将 Left 属性值设置为一个圆形的弧度值。Cos 函数返回指定一个角的余弦值,语法如下:Cos(number)参数 number 表示一个以弧度为单位的角。Cos 函数的 number 参数为一个角,并返回直角三角形两边的比值,该比值为角的邻边长度除以斜边长度之商,将角度除以 180 后即能角度转换为弧度。第 8 行代码设置图片填充的前景色随着循环的过程不断的变化。使用 Fill 属性返回一个 FillFormat 对象,FillFormat 对象代表图形的填充格式,其 ForeColor 属性设置对象填充的前景色。第
35、9 行到第 11 行代码在图形移动的过程中使用 IncrementRotation 方法设置图形绕 z 轴的转角,IncrementRotation 方法以指定的度数为增量,更改指定的图形绕 z 轴的转角,语法如下:expression.IncrementRotation(Increment)参数 expression 是必需的,返回一个 Shape 对象。参数 Increment 是必需的,以度为单位指定图形在水平方向的旋转量,正值使图形按顺时针方向旋转,负值使图形按逆时针方向旋转。其中第 11 行是关键的代码,使用 DoEvents 函数转让控制权,否则达不到预计的视觉效果。运行 Move
36、Shape 过程,工作表的图形在自身进行逆时针方向旋转的同时沿着一个圆形的弧度进行移动,并不断改变其填充的颜色。技巧 5 工作表中自动插入图片在日常工作中经常需要在工作表中插入大量图片,比如在如 图 58-1 所示的工作表中需要根据 A 列的名称在 C 列插入保存在同一目录中的相应的图片,如果使用手工插入不仅非常繁琐且极易出错,而使用 VBA 代码可以很好的完成操作。14图 5-1 需插入图片的工作表示例代码如下:#001 Sub insertPic()#002 Dim i As Integer#003 Dim FilPath As String#004 Dim rng As Range#00
37、5 Dim s As String#006 With Sheet1#007 For i = 3 To .Range(“a65536“).End(xlUp).Row#008 FilPath = ThisWorkbook.Path & “ & .Cells(i, 1).Text & “.jpg“#009 If Dir(FilPath) “ Then#025 MsgBox s & Chr(10) & “没有照片!“#026 End If#027 End Sub代码解析:insertPic 过程使用 Insert 方法在工作表中插入图片。第 7 行代码开始 For.Next 循环,循环的终值由工作表中
38、 A 列单元格的行数所决定。第 8 行代码字符串变量 FilPath 保存 A 列名称单元格所对应的图片文件的路径和文件名,本例中图片文件的文件名应和 A 列中的名称一致。第 9 行到第 11 行代码使用 Dir 函数在同一文件夹中查找与 A 列单元格中的名称相对应的图片文件,如果对应的图片文件存在则使用 Insert 方法将图片插入到工作表中,并将C 列的单元格赋给变量 rng。Dir 函数返回一个 String,用以表示一个文件名、目录名或文件夹名称,它必须与指定的模式或文件属性、或磁盘卷标相匹配。如果已没有合乎条件的文件,则 Dir 函数会返回一个零长度字符串 (“)。第 12 行到第
39、17 行代码,当图片片插入到工作表时其实是插入到活动单元格的,此时需设置图片的 Top 属性和 Left 属性将图片移动到 C 列所对应的单元格中,并设置其 Width属性和 Height 属性使其适应所在单元格的大小。第 18、19 行代码如果在同一文件夹中没有与 A 列单元格对应的图片文件,则使用字符串变量 s 保存没有图片文件的名称。第 24 行到第 26 行代码如果字符串变量 s 不等于空白说明文件夹中缺少图片文件,使用消息框提示。运行 insertPic 过程工作表如 图 58-2 所示。16图 5-2 插入图片后的工作表如果文件夹中缺少对应的图片文件,则会进行提示,如 图 58-3
40、 所示。图 5-3 缺少图片文件提示技巧 6 固定工作表中图形的位置17工作表中插入的图片,一般都是固定的尺寸和固定的单元格区域中的,但在实际使用中可能因一些人为的因素导致图片位置偏移或尺寸变化,此时可以使用 VBA 代码进行调整,如下面的代码所示。#001 Sub ShapeAddress()#002 Dim rng As Range#003 Set rng = Sheet1.Range(“B4:E22“)#004 With Sheet1.Shapes(“Picture 1“)#005 .Rotation = 0#006 .Select#007 With Selection#008 .Top
41、 = rng(1).Top + 1#009 .Left = rng(1).Left + 1#010 .Width = rng.Width - 0.5#011 .Height = rng.Height - 0.5#012 End With#013 End With#014 Range(“A1“).Select#015 End Sub代码解析:ShapeAddress 过程调整指定图形在工作表中的位置。第 3 行代码变量 rng 保存工作表中插入图片的单元格区域。 。第 5 行代码设置图片的转角,应用于 Shape 对象 Rotation 属性以度为单位返回或设置图形的转角,设置为正值向右偏转,设
42、置为负值向左偏转,设置为零图片则保持 90 度垂直。第 7 行到第 12 行代码设置图片的 Top 属性和 Left 属性将图片移动到变量 rng 所保存的单元格区域中,并设置其 Width 属性和 Height 属性使其适应所在单元格区域的大小。第 14 行代码选择 A1 单元格,不然图片会处于选中状态。经过以上设置,工作表中的图片“Picture 1”不管处于什么状态都可以一键恢复其原来的大小、位置。18技巧 7 使用 VBA自动生成图表在实际工作中我们常用图表来表现数据间的某种相对关系,一般采用手工插入的方式,而使用 VBA 代码可以在工作表中自动生成图表,如下面的示例代码。#001 S
43、ub ChartAdd()#002 Dim myRange As Range#003 Dim myChart As ChartObject#004 Dim R As Integer#005 With Sheet1#006 .ChartObjects.Delete#007 R = .Range(“A65536“).End(xlUp).Row#008 Set myRange = .Range(“A“ & 1 & “:B“ & R)#009 Set myChart = .ChartObjects.Add(120, 40, 400, 250)#010 With myChart.Chart#011 .C
44、hartType = xlColumnClustered#012 .SetSourceData Source:=myRange, PlotBy:=xlColumns#013 .ApplyDataLabels ShowValue:=True#014 .HasTitle = True#015 .ChartTitle.Text = “图表制作示例“#016 With .ChartTitle.Font#017 .Size = 20#018 .ColorIndex = 3#019 .Name = “华文新魏“#020 End With#021 With .ChartArea.Interior#022 .
45、ColorIndex = 8#023 .PatternColorIndex = 1#024 .Pattern = xlSolid#025 End With#026 With .PlotArea.Interior#027 .ColorIndex = 35#028 .PatternColorIndex = 119#029 .Pattern = xlSolid#030 End With#031 .SeriesCollection(1).DataLabels.Delete#032 With .SeriesCollection(2).DataLabels.Font#033 .Size = 10#034
46、.ColorIndex = 5#035 End With#036 End With#037 End With#038 Set myRange = Nothing#039 Set myChart = Nothing#040 End Sub代码解析:ChartAdd 过程在工作表中自动生成图表,图表类型为簇状柱形图。第 6 行代码使用 Delete 方法删除工作表中已经存在的图表,而 ChartObjects 方法返回代表工作表中单个嵌入图表(ChartObject 对象)或所有嵌入图表的集合(ChartObjects对象)的对象,语法如下:expression.ChartObjects(Inde
47、x)其中参数 Index 是可选的,指定图表的名称或号码。该参数可以是数组,用于指定多个图表,因为示例中只有一个图表,所以无需指定其 Index 参数。第 8 行代码指定图表的数据源。第 9 行代码使用 Add 方法创建一个新图表,应用于 ChartObjects 对象的 Add 方法创建新的嵌入图表,语法如下:expression.Add(Left, Top, Width, Height)参数 Left、Top 是必需的,以磅为单位给出新对象的初始坐标,该坐标是相对于工作表上单元格 A1 的左上角或图表的左上角的坐标。参数 Width、Height 是必需,以磅为单位给出新对象的初始大小。第 10 行代码使用 Chart 属性返回新创建的图表,应用于 ChartObject 对象的 Chart 属性返回一个 Chart 对象,该对象代表指定对象所包含的图表。第 11 行代码指定新创建图表的图表类型,应用于 Chart 对象的 Cha