[ 更换 ]
热门城市
北京上海广州深圳成都杭州南京武汉天津西安重庆青岛沈阳长沙大连厦门无锡福州济南宁波昆明苏州郑州长春合肥南昌哈尔滨常州烟台南宁温州石家庄太原珠海南通扬州贵阳东莞徐州大庆佛山威海洛阳淮安呼和浩特镇江潍坊桂林中山临沂咸阳包头嘉兴惠州泉州三亚赣州九江金华泰安榆林许昌新乡舟山慈溪南阳聊城海口东营淄博漳州保定沧州丹东宜兴绍兴唐山湖州揭阳江阴营口衡阳郴州鄂尔多斯泰州义乌汕头宜昌大同鞍山湘潭盐城马鞍山襄樊长治日照常熟安庆吉林乌鲁木齐兰州秦皇岛肇庆西宁介休滨州台州廊坊邢台株洲德阳绵阳双流平顶山龙岩银川芜湖晋江连云港张家港锦州岳阳长沙县济宁邯郸江门齐齐哈尔昆山柳州绍兴县运城齐河衢州太仓张家口湛江眉山常德盘锦枣庄资阳宜宾赤峰余姚清远蚌埠宁德德州宝鸡牡丹江阜阳莆田诸暨黄石吉安延安拉萨海宁通辽黄山长乐安阳增城桐乡上虞辽阳遵义韶关泸州南平滁州温岭南充景德镇抚顺乌海荆门阳江曲靖邵阳宿迁荆州焦作丹阳丽水延吉茂名梅州渭南葫芦岛娄底滕州上饶富阳内江三明淮南孝感溧阳乐山临汾攀枝花阳泉长葛汉中四平六盘水安顺新余晋城自贡三门峡本溪防城港铁岭随州广安广元天水遂宁萍乡西双版纳绥化鹤壁湘西松原阜新酒泉张家界黔西南保山昭通河池来宾玉溪梧州鹰潭钦州云浮佳木斯克拉玛依呼伦贝尔贺州通化朝阳百色毕节贵港丽江安康德宏朔州伊犁文山楚雄嘉峪关凉山雅安西藏四川广东河北山西辽宁黑龙江江苏浙江安徽福建江西山东河南湖北湖南海南贵州云南陕西甘肃青海台湾内蒙古广西宁夏香港澳门
培训资讯网 - 为兴趣爱好者提供专业的职业培训资讯知识

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

学会 让你

在VBA宏模块中编写代码其实并不是想象中的那么难,虽然代码看上去比较啰嗦复杂,但是如果你利用“录制宏”的功能来生成代码就非常容易了,然后再对生成的代码进行适当修改,代码是按照你的操作步骤一步一步生成的,每一步你的操作与代码对应,这样很容易修改生成的代码。

录制宏:

找到视图下的宏,找到录制功能:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

录制宏模块

给宏取名:

按功能输入宏模块的名称:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

给宏模块命名

手动作图:

先用手动选择数据画想要生成的图形:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

先用手动选择数据画想要生成的图形

停止录制:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

画好图后停止录制宏

查看宏:

找到名称,点编辑进入代码窗口:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

编辑宏代码

点开编辑,查看系统自动生成的代码:

Sub curve()
    Range("G702:H744").Select
    ActiveSheet.Shapes.AddChart.Select
    ActiveChart.SetSourceData Source:=Range("数据1!$G$702:$H$744")
    ActiveChart.ChartType = xlLineMarkers
    ActiveChart.SeriesCollection(1).Select
    ActiveSheet.ChartObjects("图表 1").Activate
    ActiveSheet.ChartObjects("图表 1").Activate
    ActiveChart.Axes(xlCategory).Select
    ActiveSheet.ChartObjects("图表 1").Activate
    ActiveChart.Axes(xlCategory).Select
    ActiveChart.Axes(xlCategory).TickLabelSpacing = 1
    ActiveChart.Axes(xlCategory).TickLabelSpacing = 3
    ActiveChart.Axes(xlCategory).TickLabelSpacing = 5
End Sub

Range("G702:H744").Select:选择数据范围

ActiveSheet.Shapes.AddChart.Select:当前激活表插入图形

ActiveChart.SetSourceData Source:=Range("data1!$G$702:$H$744"):选择源数据

ActiveChart.ChartType = xlLineMarkers:图形类型选折线类型

ActiveChart.SeriesCollection(1).Select:选择系列

ActiveSheet.ChartObjects("图表 1").Activate:激活图表

ActiveChart.Axes(xlCategory).Select:选择坐标轴

ActiveChart.Axes(xlCategory).TickLabelSpacing = 5:坐标轴文本标签间隔设置为5

可以看出,你的每一步操作都自动生成了代码,而且是严格对应的,有些方法和属性你不知道怎么用,但是如果录制宏自动生成代码,你就知道怎么调用和引用了,这样下一步对于我们来修改程序,批量选择数据,批量生成多个曲线奠定了基础。

下面对8个数据表同时操作,生成曲线图:

数据简单处理:把数据为0的值都处理成空值,在画图的时候越过这些值

处理代码:

Sub dataOperation()
    Dim str3()
    str3() = Array("", "data1", "data2", "data3", "data4", "data5", "data6", "data7", "data8")
    For m = 2 To 24 Step 2
        For j = 2 To 200
            If Sheets(str3(5)).Cells(j, m) = 0 Then
                For i = 1 To 8
                    Sheets(str3(i)).Cells(j, m).ClearContents
                Next i
            End If
        Next j
    Next m
End Sub

新生成列数据(用已有列数据进行自动计算):

Sub dataCreate()
    str1 = "源数据": str2 = "F": str3 = "I": str4 = "L": str5 = "J": str6 = "K": str7 = "G"
    For i = 2 To 1761
        If Sheets(str1).Cells(i, str2) > 0 And Sheets(str1).Cells(i, str3) = " " Then
            Sheets(str1).Cells(i, str3) = Sheets(str1).Cells(i, str2) / Sheets(str1).Cells(i, str4)
            Sheets(str1).Cells(i, str5) = 0
            Sheets(str1).Cells(i, str6) = 100 - Sheets(str1).Cells(i, str5) / Sheets(str1).Cells(i, str3) * 100
        End If
    Next i
End Sub

画图代码:

通过录制宏,然后手动修改宏,再额外加一些简单的循环代码,实现多表和多图操作

Sub imageCreate()
    "定义数组变量:
    Dim str1(1 To 12), str3()
    Dim y(1 To 12)
    Dim ysz()
    "按照实际对8个或者更多个数据表进行作图:
    mm8 = 1
    str3() = Array("", "data1", "data2", "data3", "data4", "data5", "data6", "data7", "data8")
    ysz() = Array(0, 7, 3, 10, 32, 28, 28, 4, 32)
    "每个循环代表对一个数据表进行作图
    For i2 = 1 To 8
        "激活相应数据表
        Select Case i2
               Case i2
                    Sheets(str3(i2)).Activate
        End Select
        m = 64
        For i1 = 1 To 12
             Select Case i2
               Case i2
                    Sheets(str3(i2)).Activate
        End Select
        "数据区域选择:
        str2 = Chr(i1 + m)
        y(i1) = Application.WorksheetFunction.CountA(Range(CStr(str2) + "1" + ":" + CStr(str2) & "10000"))
        str1(i1) = CStr(str2) + "1" + ":" + CStr(Chr(i1 + m + 1)) & CStr(y(i1))
        m = m + 1
        Range(str1(i1)).Select
        "对图形进行相应操作,包括图形类型,线型,颜色,系列名称,标记大小、图名等:
        ActiveSheet.Shapes.AddChart.Select
        With Selection
            .Shadow = False
        End With
        ActiveChart.SetSourceData Source:=Range(str3(i2) + "!" + "$" + str2 + "$2:$" + CStr(Chr(i1 + m)) + "$" + CStr(y(i1)))
        ActiveChart.ChartType = xlLineMarkers
        ActiveChart.Legend.Select
        Selection.Delete
        ActiveChart.SeriesCollection(1).Name = "=" + """ + str3(i2) + """ + "!" + "$" + str2 + "$1"
        ActiveChart.Location Where:=xlLocationAsObject, Name:="曲线图" + CStr(mm8)
        ActiveChart.SeriesCollection(1).Select
        ActiveChart.SeriesCollection(1).Smooth = True
        With Selection.Border
            .ColorIndex = ysz(i2)
            .Weight = xlMedium
            .LineStyle = xlContinuous
        End With
        With Selection
            .MarkerBackgroundColorIndex = ysz(i2)
            .MarkerForegroundColorIndex = ysz(i2)
            .MarkerStyle = xlDiamond
            .Smooth = ture
            .MarkerSize = 5
            .Shadow = False
        End With
        ActiveChart.ChartArea.Select
        "删除标题,如果想实现某一功能,可能通过录制宏然后再修改代码
        If i2 <> 6 Then
        ActiveChart.ChartTitle.Select
        Selection.Delete
        End If
        If i2 <> 4 Then
        With Selection.Border
            .LineStyle = 0
        End With
        With ActiveChart
            .HasAxis(xlCategory, xlPrimary) = False
            .HasAxis(xlValue, xlPrimary) = True
        End With
        ActiveChart.Axes(xlCategory, xlPrimary).CategoryType = xlAutomatic
        ActiveChart.Axes(xlValue).Select
        With Selection.Border
            .ColorIndex = 57
            .Weight = xlMedium
            .LineStyle = xlContinuous
        End With
        ElseIf i2 = 4 Then
        With Selection.Border
            .LineStyle = 0
        End With
        ActiveChart.Axes(xlCategory, xlPrimary).CategoryType = xlAutomatic
        ActiveChart.Axes(xlValue).Select
        Selection.TickLabels.NumberFormatLocal = "0_ "
        "设置标记线样式
        With Selection
        .TickLabels.NumberFormatLocal = "0_ "
            .MajorTickMark = xlInside
        End With
        With Selection.Border
            .ColorIndex = 57
            .Weight = xlMedium
            .LineStyle = xlContinuous
        End With
         With Selection
            .MajorTickMark = xlInside
            .MinorTickMark = xlNone
            .TickLabelPosition = xlNextToAxis
        End With
        ActiveChart.Axes(xlCategory).Select
        With Selection.Border
            .ColorIndex = 57
            .Weight = xlMedium
            .LineStyle = xlContinuous
        End With
        End If
        With ActiveChart.Axes(xlCategory)
            .HasMajorGridlines = False
            .HasMinorGridlines = False
            .MajorTickMark = xlInside
        End With
        With ActiveChart.Axes(xlValue)
            .HasMajorGridlines = False
            .HasMinorGridlines = False
            .MajorTickMark = xlInside
        End With
        ActiveChart.PlotArea.Select
        With Selection.Border
            .Weight = xlThin
            .LineStyle = xlNone
        End With
        "对图表和曲线相应设置进行操作
        Selection.Interior.ColorIndex = xlNone
        ActiveChart.Axes(xlValue).Select
        ActiveChart.PlotArea.Select
        ActiveChart.ChartArea.Select
        ActiveSheet.Shapes(ActiveSheet.Shapes.Count).IncrementLeft 278.41
        ActiveSheet.ChartObjects(ActiveSheet.Shapes.Count).Activate
        ActiveChart.ChartArea.Shadow = False
        "对曲线显示位置操作
        ActiveChart.ChartArea.Select
        ActiveSheet.Shapes(ActiveSheet.Shapes.Count).IncrementLeft 660 * i1
        If i2 <> 5 And i2 <> 6 And i2 <> 7 And i2 <> 8 Then
        ActiveSheet.Shapes(ActiveSheet.Shapes.Count).IncrementTop 70 * (i2 + 3)
        End If
        If i2 = 5 Then
        ActiveSheet.Shapes(ActiveSheet.Shapes.Count).IncrementTop 70 * (0 + 3)
        End If
         If i2 = 6 Or i2 = 7 Or i2 = 8 Then
        ActiveSheet.Shapes(ActiveSheet.Shapes.Count).IncrementTop 70 * (i2 - 6)
        End If
        ActiveSheet.Shapes(ActiveSheet.Shapes.Count).ScaleWidth 1.8, msoFalse, msoScaleFromTopLeft
        ActiveSheet.Shapes(ActiveSheet.Shapes.Count).ScaleHeight 0.38, msoFalse, msoScaleFromTopLeft
        Next i1
    Next i2
End Sub

点击运行模块代码:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

点击运行

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

宏代码模块

运行完毕,打开EXCEL,批量图形展现于此:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

数百个曲线图自动一次成图

研究开发Excel中VBA宏模块自动调用Excel的图表制作功能,自动生成数百个曲线图,并且能够根据成图数据自动设置坐标数值、字体及大小、曲线图的形状、颜色及显示方式等参数,实现曲线图的快速成图和自动调整外观及坐标参数。

还可以应用VB程序开发工具编写程序自动从服务器提取和处理需要的数据,按特定格式输出到Excel数据表格中,通过编写宏代码,应用Excel中VBA宏模块调用Excel的图表制作功能,自动生成曲线图,并通过编写VB程序代码设定特定格式数据,通过编写VBA宏模块代码调用数据进行图自动的生成和自动参数设置,实现多组曲线图快速生成和快速坐标及外观设置的目的。

进阶思想:

要想从数据提取,生成新的数据,再到批量成图,需要有完整的思路

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

功能分类设计图

实现流程图:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

实现流程图

成功自动生成数据后,导入VBA模块:

文科生也能轻松学会VBA编程,Excel中VBA宏模块,让你随处可用

生成数据,导入模块

运行模块

相关内容

怎么学?如何干?西藏7市(地)委书记在西藏日报发表文章

启航新征程 开创新局面为全面建设社会主义现代化新拉萨努力奋斗自治区党委常委、拉萨市委书记 普布顿珠党的二十大大笔擘画坚持以中国式现代化全面推进中华民族伟大复兴的宏伟蓝图,区党委十届三次全会全面铺开建设美丽幸福西藏、共圆伟大复兴梦想的壮阔实践···

2023年全区智慧旅游专业人才培训班圆满结业

6月2日,自治区旅游发展厅主办的全区智慧旅游专业人才培训班在拉萨圆满结业。培训共历时三天,累计完成全区旅游行政管理部门工作人员及涉旅企业专业技术人员培训100人。本次培训是区旅发厅深入推进学习贯彻习近平新时代中国特色社会主义思想主题教育重要···

徐汇萨迦共同举办大美西藏首届口腔学习班

随着现代医学的发展,口腔健康越来越受到人们的关注,为提高西藏地区口腔技术水平和服务质量,近日,徐汇区牙病防治所和萨迦县中心医院远程连线共同举办首届口腔学习班开班仪式。徐汇区卫生健康委副主任胡强,上海援藏干部、萨迦县委常务副书记、常务副县长沈···

自觉抵制“一对一”“一对多”等学科类培训!哈尔滨中小学生暑期预警来了

17日,记者从哈尔滨市各区教育局获悉,2023年暑假将至,南岗区、道里区、香坊区教育局向家长发出预警,自觉抵制违规培训,各区义务教育阶段学科类培训机构已经全部注销,暑假期间以任何形式开展的学科类培训均属于违规培训。家长要自觉抵制任何机构或个···

哈尔滨市道里区企投局举办“招商大讲堂”专题培训

黑龙江网讯(记者 王惠婷)10月24日,哈尔滨市道里区企投局组织开展“招商大讲堂”专题培训班,全区各招商专班负责同志及业务骨干参加培训。本次培训从实际需求出发,紧紧围绕当前招商工作中的热点、难点,对“什么是招商引资”“道里区的产业结构和主导···

团黑龙江省委举办全省青年文明号青年岗位能手学习宣传贯彻党的二十大精神培训交流会

中国青年报客户端讯(李海涛)为深入学习贯彻党的二十大精神,充分发挥青年文明号、青年岗位能手示范引领作用,在全省职业青年中掀起学习党的二十大精神热潮,11月22日,团黑龙江省委举办全省青年文明号青年岗位能手学习宣传贯彻党的二十大精神培训交流会···

辽宁葫芦岛举办外贸政策培训会推动外贸保稳增量

辽宁省葫芦岛市外贸政策培训会4月3日举办。 辽宁省贸促会供图中新网葫芦岛4月3日电 (李晛)辽宁省葫芦岛市外贸政策培训会4月3日举办。本次活动由辽宁省贸促会支持、葫芦岛市商务局主办,葫芦岛市贸促会、葫芦岛海关、中国出口信用保险辽宁分公司和辽···

山西运城:严查无证校外培训机构 查封9家警告2家

新华社太原8月5日电(记者王飞航)记者从山西省运城市政府了解到,运城市教育局近日联合市公安局等多家单位,对中心城区无证校外培训机构进行了一次突击检查,共检查了13家校外培训机构,查封9家,警告2家,发放整改通知书4份。今年7月,运城市教育局···

山西开展培训筑牢森林“防火墙”

山西新闻网3月30日讯(记者 卢奕如)今日,记者从山西省应急管理厅获悉,全省举办森林草原防灭火业务培训,邀请专家以视频会议形式,围绕森林扑火指挥实操、森林草原火灾防控经验做法、火灾现场各级各类指挥员具体操作中遇到的问题等内容进行授课。培训内···

校外培训机构治理工作取得进展 山西停办近1300所

资料图:小学生排队等待进入校园。中新社记者 刘文华 摄中新网5月11日电 据教育部网站消息,按照校外培训机构专项治理工作整体安排,教育部、民政部、国家市场监管总局启动了校外培训机构治理专项督查工作。5月9日至10日,督查组率先在北京市开展华···

山西综改区举办省技术创新中心申报培训

  8月18日,山西综改区科技金融部举办2023年度省技术创新中心申报培训会,来自区内企业、科研院所及有关单位代表160余人参加了培训。  山西省技术创新中心是以产业前沿引领技术和关键共性技术研发为核心的产业技术创新平台,承担着为区域和产业···

山西汾阳医院开展健康教育与控烟知识培训

来源:【吕梁日报-吕梁新闻网】本报讯 (记者 刘少伟) 5月18日,在“世界无烟日”到来之际,山西汾阳医院组织开展健康教育与控烟知识培训。近年来,山西汾阳医院全面落实健康中国战略,根据国家卫健委《关于2011年起全国医疗卫生系统全面禁烟的决···

山西省文物局年度田野考古技术培训班开班

10月10日,山西省文物局在运城闻喜上郭城址、邱家庄墓群举办2023年度田野考古技术培训班开班仪式。该次培训为期三个月,通过理论和实践两部分教学,旨在推进山西考古工作高质量发展,提升考古业务人员专业技术水平。本次培训由山西省考古研究院和山西···

最低每课时9元!全省学科类校外培训课时长和收费标准出台

近日,山西省发改委、省教育厅下发《关于中小学学科类校外培训收费标准及有关事项的通知》,明确全省中小学学科类校外培训收费标准,从12月17日起执行。《通知》对全省线上线下学科类校外培训基准收费标准和浮动幅度制定了科学标准。其中,义务教育阶段线···

山西天镇 阳光职业培训学校培养乡村“新农人”乡村振兴添动能

(记者 贺文生) 山西天镇县阳光职业培训学校紧紧围绕乡村振兴战略,按照“政府引导、农民自愿、立足产业、突出重点”的原则,创新高素质农民技能培训方式方法,采取以“授人以渔”的方式,让人才振兴成为助推农业农村现代化的内生动力,以高素质农民引领现···

山西:建立全过程 全链条 无缝隙安全培训制度

黄河新闻网讯(记者杨江涛)日前,山西省应急管理厅下发了《山西省安全培训管理暂行办法》(以下简称《办法》)。我省将进一步抓好安全生产这个基本盘、基本面,推动全省安全培训工作制度化、规范化、科学化,促进安全培训工作高质量发展。山西省应急管理厅厅···

山西:艺考培训机构纳入全国监管平台管理

央广网太原10月6日消息(记者郎麒) 日前,山西省教育厅、省发改委、省公安厅等部门联合制定《加强面向高中阶段学生艺考培训规范管理工作方案》,针对艺考培训的突出特点和实际情况,全面规范艺考培训行为,将艺考培训机构统一纳入全国校外教育培训监管与···

太平财险阳泉中支开展消防安全教育和有限空间作业培训

为强化员工安全意识,进一步提升员工消防和有限空间突发事件应急处理能力,9月14日,太平财险阳泉中支邀请北京市卫民安消防教育咨询中心山西分中心讲师向全体员工开展了一次消防安全教育和有限空间作业课程培训。按照防消结合、预防为主的原则,本次讲座通···

山西省数字化转型贯标试点工作宣贯培训会在太原举行

  10月20日消息,山西省数字化转型贯标试点工作宣贯培训会在太原举行。省工信厅介绍,作为国家数字化转型贯标试点省份,试点启动后将引导企业加快数字化转型,助力制造业高端化、智能化、绿色化发展。  今年,工信部启动数字化转型贯标试点工作,我省···

山西马兰花创业培训讲师大赛收官 太原市获多个奖项

山西新闻网8月31日讯(记者 冯耿姝)8月29日,山西省第四届马兰花创业培训讲师大赛圆满收官,太原市代表队在比赛中分获多个二、三等奖和优秀奖。本届大赛以“启迪创新思维·激发创业梦想”为主题,全省共有56名教师晋级复赛,其中,太原市有7名选手···