最近一直在研究VBA,写报表的工作。将所得的知识,经验总结一下,与大家分享。

工具篇,VBA

1.EXCEL一个最好用的功能就是录制宏,当一个函数拿不准要怎么写,用什么函数表示的时候,录制就帮了大忙了。

2.VBA相对于录制的宏,可以更精确,更聪明,逻辑更清晰,执行也更有效。特别是它的循环和递归,直接解放了人的双手。

3.VBA的基本操作

(1)定位:

基本单位:sheets(页),Rows(行),Columns(列),cells(单元格),RANGE(一个范围的单元格)

相对于每个基本单位,我们都可以选择跳转(select),清空(clear),取消合并(UnMerge),合并(Merge).删除(delete),激活(activate),复制(copy),粘贴(paste)

其实它并不局限于当前的某行某列,更加有效的方法是在规则上的控制。比如:某页的最后一行,某页的最后一列。

这样的方式就会更加灵活。

LastRow = Sheets("名称“).Range("a65536").End(xlUp).Row  ‘取数据表的最后一行数据的行号

Lastcol = Sheets("名称").Cells(6, 255).End(xlToLeft).Column     '取数据部的第六行的最后一列的数据。

(2) 时间

如果你想定位时间,比如今天

1.直接用EXCEL的函数。并且只取其值,不取函数。

Range("D6").Select
    ActiveCell.FormulaR1C1 = "=Today()"
    Range("D6") = Range("D6").Value

2. VBA函数DATE.

Range("D6").Select

Range("D6").Value=date

(3).排版

列宽

Columns("C").ColumnWidth = 5
    Columns("B").ColumnWidth = 22
    Range(Columns(4), Columns(40)).ColumnWidth = 9

行宽

(4).循环

while

........

wend

优点:当有两个表,或者两个变量的时候,该while特别好用。

for i =0 to 18 step 2

......

next

优点:特别适合一张表。

(5)条件判断

IF .....THEN.....  ENDIF条件判断的利器

多个条件判断用case when

Select Case LRegion
Case "N"
LRegionName = "North"
Case "S"
LRegionName = "South"
Case "E"
LRegionName = "East"
Case "W"
LRegionName = "West"
End Select

(6) 统计

1 COUNTIF.  Application.CountIf(Range(Cells(8, 3), Cells(32, 3)), "Up")  统计范围内”UP“的个数。

2 VLOOKUP.Application.VLookup(Cells(mNum, 2), Worksheets("UMP关键key值").Range("A:I"), 9, 0) 查询函数。

(7)创建新页并起名

Sheets.Add After:=Sheets(Sheets.count)
    
aa = Sheets("名称").Cells(38, i)
Sheets(Sheets.count).Name = aa
Sheets(Sheets.count).Select

(8)连字符&。具有无比的粘性,将字符和数字连在一起。

aa = Sheets("UMP关键key值").Range("I" & i)
    ab = Sheets("UMP关键key值").Range("J" & i)
    ac = aa & " - " & ab

(9)空白行删除

Range("a1:a" & LastRow).SpecialCells(xlCellTypeBlanks).Select
Selection.EntireRow.Delete

(10)图表的制作和定位。

Set ab = Range("I" & 2 * i & ":g" & 2 * i + 1)-----位置
Set bbb = ActiveSheet.ChartObjects.Add(0, 0, 0, 0)
bbb.Chart.ChartType = xlPie  --饼图,  bbb.Chart.ChartType = xlDoughnut  --圆环
bbb.Chart.SetSourceData Source:=Range("F" & 2 * i & ":G" & 2 * i + 1)---数据源
bbb.Chart.SetElement (msoElementLegendNone)

圆环的大小尺寸

bbb.Chart.SeriesCollection(1).Select
bbb.Chart.ChartGroups(1).DoughnutHoleSize = 70

If Cells(2 * i, 5).Value > 0 Then
bbb.Chart.ChartStyle = 4
Else
bbb.Chart.ChartStyle = 3
End If-----颜色分布

With bbb
.Top = ab.Top
.Left = ab.Left
.Width = ab.Width
.Height = ab.Height
End With

(11)函数取整。

t = Int(Cells(2 * i, 3) / Cells(2 * i, 4))

(12)加文本框

Set cd = Sheets("图表").Range("C" & i + 5 + (i - 1) * 10 & ":c" & i + 6 + (i - 1) * 10)-位置
Set ddd = ActiveSheet.Shapes.AddTextbox(msoTextOrientationHorizontal, 0, 0, 0, 0) --创建文本框
With ddd
.Top = cd.Top
.Left = cd.Left
.Width = cd.Width
.Height = cd.Height
End With
ddd.Select
Selection.ShapeRange.Line.Visible = msoFalse -无框
Selection.ShapeRange(1).TextFrame2.TextRange.Characters.Text = Int(Abs(Sheets("数据").Cells(2 * i, 5).Value) * 100) & "%"
With Selection.ShapeRange(1).TextFrame2.TextRange.Characters.Font
.NameComplexScript = "+mn-cs"
.NameFarEast = "+mn-ea"
.Fill.Visible = msoTrue
.Fill.ForeColor.ObjectThemeColor = msoThemeColorDark1
.Fill.ForeColor.TintAndShade = 0
.Fill.ForeColor.Brightness = 0
.Fill.Transparency = 0
.Fill.Solid
.Size = 13 -字体
.Name = "+mn-lt"

End With

(13)添加箭头

For i = 1 To lastrow - 1
Sheets("图表").Activate
Set mn = Sheets("图表").Range("C" & 6 + (i - 1) * 11) -位置

If Sheets("数据").Cells(2 * i, 5).Value > 0 Then
Set ooo = ActiveSheet.Shapes.AddShape(msoShapeUpArrow, 0, 0, 0, 0) -上箭头
With ooo
.Top = mn.Top
.Left = 158.25
.Width = 3.6
.Height = 33
End With
ooo.Select
Selection.ShapeRange.ShapeStyle = msoShapeStylePreset10 红色
Else
Set ooo = ActiveSheet.Shapes.AddShape(msoShapeDownArrow, 0, 0, 0, 0) 下箭头
With ooo
.Top = mn.Top
.Left = 158.25
.Width = 3.6
.Height = 33
End With
ooo.Select
Selection.ShapeRange.ShapeStyle = msoShapeStylePreset9
End If
Next

(14) 组合

For i = 1 To lastrow - 1
Sheets("图表").Activate
If Sheets("数据").Cells(2 * i, 5).Value > 0 Then
ActiveSheet.Shapes.Range(Array("TextBox " & (i + 15), "Up Arrow " & (30 + i), "Chart " & i)). _
Select
Else
ActiveSheet.Shapes.Range(Array("TextBox " & (i + 15), "Down Arrow " & (30 + i), "Chart " & i)). _
Select
End If
Selection.ShapeRange.Group.Select -组合

Next

(15)文本

Range("A3").Value = "数据提取时间:" & Int(Now() - 1) & " 17:00 至 " & Int(Now()) & " 17:00"

VBA 之所以比其他的编程语言简单,第一是数据都在excel的单元格中,调试起来比较的简单。

第二就是它的语言录制功能。函数的使用比较简单。

第三就是EXCEL和PPT的交互做的非常好,EXCEL数据的更新可以直接在PPT中体现。

(16) 趋势

http://hy-chou.blogspot.hk/2012/11/excel.html

VBA的缺点是只是针对单个文档做的,所以微软在之后的版本可能不会对他升级了。js为将来的趋势。

(17)表格颜色 Cells(i, 14).Interior.ColorIndex = 45

For i = 32 To lastrow12
If Range("N" & i).Value = green(0) Or Range("N" & i).Value = green(1) Or Range("N" & i).Value = green(2) Or Range("N" & i).Value = green(3) Or Range("N" & i).Value = green(4) Or Range("N" & i).Value = green(5) Then Cells(i, 14).Interior.ColorIndex = 10
If Range("N" & i).Value = yellow(0) Or Range("N" & i).Value = yellow(1) Then Cells(i, 14).Interior.ColorIndex = 45
If Range("N" & i).Value = "现货降低,周转提升" Then Cells(i, 14).Interior.ColorIndex = 3

next

表格颜色对照表

http://www.360doc.com/content/11/0126/08/395863_89065041.shtml

(18)arrary 的定义,起到数组的作用

green = Array("现货提升,周转降低", "现货提升,周转提升", "现货提升,周转稳定", "现货稳定,周转降低", "现货稳定,周转提升", "现货稳定,周转稳定")
yellow = Array("现货降低,周转降低", "现货降低,周转稳定")

报表研究之工具篇-VBA的更多相关文章

  1. 报表研究之PPT篇

    PPT是一种说服力,是展示,也是营销. PPT写的好,会有事半功倍的效果. 写好PPT,重要的有以下几点. 1.1页1主题,1行1观点 2.善用图形,图成逻辑 3.微软雅黑最佳,其余字体配搭 4.色同 ...

  2. 【工具篇】利用DBExportDoc V1.0 For MySQL自动生成数据库表结构文档

    对于DBA或开发来说,如何规范化你的数据库表结构文档是灰常之重要的一件事情.但是当你的库,你的表排山倒海滴多的时候,你就会很头疼了. 推荐一款工具DBExportDoc V1.0 For MySQL( ...

  3. 大数据工具篇之Hive与MySQL整合完整教程

    大数据工具篇之Hive与MySQL整合完整教程 一.引言 Hive元数据存储可以放到RDBMS数据库中,本文以Hive与MySQL数据库的整合为目标,详细说明Hive与MySQL的整合方法. 二.安装 ...

  4. JVM调优-工具篇

    原文地址 16年的时候花了一些时间整理了一些关于jvm的介绍文章,到现在回顾起来还是一些还没有补充全面,其中就包括如何利用工具来监控调优前后的性能变化.工具做为图形化界面来展示更能直观的发现问题,另一 ...

  5. 工具篇-MAT(Memory Analyzer Tool)

    --- layout: post title: 工具篇-MAT(Memory Analyzer Tool) description: 让内存泄漏无所遁形 2015-10-08 category: bl ...

  6. 工具篇-TraceView

    --- layout: post title: 工具篇-TraceView  description: 让我们远离卡顿和黑屏 2015-10-09 category: blog --- ## 让我们远 ...

  7. css,js工具篇

    4. web前端开发分享-css,js工具篇   web前端开发乃及其它的相关开发,推荐sublime text, webstorm(jetbrains公司系列产品)这两个的原因在于,有个技术叫emm ...

  8. 大数据工具篇之Hive与HBase整合完整教程

    大数据工具篇之Hive与HBase整合完整教程 一.引言 最近的一次培训,用户特意提到Hadoop环境下HDFS中存储的文件如何才能导入到HBase,关于这部分基于HBase Java API的写入方 ...

  9. Linux工具XFTP、Xshell(centos配置java环境 工具篇 总结一)

    ♣Xmanager5是什么? ♣安装XFTP ♣安装Xshell 1.Xmanager5(官网:https://www.netsarang.com/download/software.html)是全新 ...

随机推荐

  1. 明文post密码

    w 作者:余天升链接:https://www.zhihu.com/question/20306241/answer/14696464 看到上面几位的回答,我真心觉得,当前信息安全保护的意识过于低下,连 ...

  2. Dev GridControl 小结3

    Dev GridControl 小结 时间 2014-03-26 19:24:01  CSDN博客 原文  http://blog.csdn.net/jiankunking/article/detai ...

  3. 作为一名合格的JAVA程序员需要点亮那些技能树?

    以下是出现次数超过100的一些技能,大家可以做一个参考. Spring 299 MySQL 290 JavaScript 216Linux 165J2EE 151设计模式 148Struts2 138 ...

  4. JQuery UI 入门

    1. JQuery UI 概述 1.1 JQuery UI 主要分为三部分: 交互部件(interactions):是一些与鼠标交互相关的内容; 小部件(widgets): 主要是一些页面的扩展; 效 ...

  5. 洛谷 P2721 小Q的赚钱计划

    洛谷 这大概是我见过最水的紫题吧- 洛谷标签赞一个! 题意:你有一年时间,把10w元存银行变成更多钱,在特定时间区间内,你会有一些利息,不过不可中途退出. 直接dp:st[i]表示区间左端点,ed[i ...

  6. python函数回顾:dir()

    描述 dir() 函数不带参数时,返回当前范围内的变量.方法和定义的类型列表: 带参数时,返回参数的属性.方法列表.如果参数包含方法__dir__(),该方法将被调用. 如果参数不包含__dir__( ...

  7. 老铁,这年头不会点git真不行

    作者:武沛齐 出处:http://www.cnblogs.com/wupeiqi/ 版本控制 说到版本控制,脑海里总会浮现大学毕业是写毕业论文的场景,你电脑上的毕业论文一定出现过这番景象! 毕业论文_ ...

  8. 0403-服务注册与发现-客户端负载均衡-Ribbon的基本使用

    一.概述 问题1.上一篇文章已说明如何注册微服务,但是调用方如何调用,以及如何防止硬编码.即电影微服务调用用户微服务 问题2.用户微服务多个节点,调用服务方如何负载均衡 二.实现负载均衡方式 2.1. ...

  9. Python基础-序列化(json/pickle)

    我们把对象(变量)从内存中变成可存储的过程称之为序列化,比如XML,在Python中叫pickling,在其他语言中也被称之为serialization,marshalling,flattening等 ...

  10. Python2 socket TCPServer 多线程并发 超时关闭

    在阿里云上测试过,可以直接使用. 用IP和端口发送数据,会返回echo:+接收到的数据 #coding=utf-8 import socket import threading,getopt,sys, ...