报表研究之工具篇-VBA

最近一直在研究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.....  条件判断的利器

(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

时间: 2024-08-29 07:53:05

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

报表研究之PPT篇

PPT是一种说服力,是展示,也是营销. PPT写的好,会有事半功倍的效果. 写好PPT,重要的有以下几点. 1.1页1主题,1行1观点 2.善用图形,图成逻辑 3.微软雅黑最佳,其余字体配搭 4.色同LOGO,突出对比和反差 5.图片写意,系列选材 如何练习自己的P感呢,一个是表,外部的形式,一个是里,内在的逻辑和分析.表和里相互影响,互为因果. 表,可以每天找一张做的好的PPT,拿来模仿,总结. 里,可以就所找的数据,拿来分析,总结.

微信开发第二篇:工具篇

自从写了第一篇后,最近一直在整理另一个项目的需求,没有继续研究下去,今天晚上终于开始了我的第二篇. 本次微信的项目是想基于H5做的,所以现在的想法还是先从前端入手. 要做一个移动端H5的网站有很多种方式: 1.使用Html5.css3.js自己从头开始做. 但如果这样,对于目前主要从事项目管理及后端开发工作的我,无疑是困难重重:另外自己也已经对前端的东西很久没碰过了.如果选择这种方式,肯定会本末倒置.最后说不定整个项目都没得戏(虽说这个项目完全是自己的个人爱好!!) 2.使用现在已有的移动端H5

反病毒攻防研究第012篇:利用Inline HOOK实现主动防御

一.前言 之前文章中所讨论的恶意程序的应对方法,都是十分被动的,即只有当恶意程序被执行后,才考虑补救措施.这样,我们就会一直处于后手状态,而如果说病毒的危害性极大,那么即便我们完美地修复了诸如注册表项,服务项等敏感位置,并且删除了病毒本身,但是它依旧可能已经破坏了系统中非常重要的文件,造成了不可逆的损伤.因此这篇文章就来简单讨论一下利用Inline HOOK技术实现主动防御,在病毒执行前,就主动将危险函数劫持,如同一道防火墙,保护我们计算机的安全. 二.Inline HOOK原理 我们平时所使用

反病毒攻防研究第015篇:病毒感染标志的添加

一.前言 对于感染型病毒而言,如果对同一个目标文件多次进行感染,有可能导致目标文件损坏,使得无法执行.所以病毒程序往往会在第一次感染时对目标文件写进一个感染标志,这样在第二次遇到该文件时,首先判断一下该文件中是否包含有感染标志,如果有,则不再感染,如果没有感染标志则进行感染(关于文件的感染,可参见<反病毒攻防研究第004篇:利用缝隙实现代码的植入>和<反病毒攻防研究第005篇:添加节区实现代码的植入>).所谓的感染标志其实就是在PE文件中无关紧要的位置写入的一个字符串,所以感染标志

JVM调优-工具篇

原文地址 16年的时候花了一些时间整理了一些关于jvm的介绍文章,到现在回顾起来还是一些还没有补充全面,其中就包括如何利用工具来监控调优前后的性能变化.工具做为图形化界面来展示更能直观的发现问题,另一方面一些耗费性能的分析(dump文件分析)一般也不会在生产直接分析,往往dump下来的文件达1G左右,人工分析效率较低,因此利用工具来分析jvm相关问题,长长可以到达事半功倍的效果来. jvm监控分析工具一般分为两类,一种是jdk自带的工具,一种是第三方的分析工具.jdk自带工具一般在jdk bin

Caffe学习系列——工具篇:神经网络模型结构可视化

Caffe学习系列--工具篇:神经网络模型结构可视化 在Caffe中,目前有两种可视化prototxt格式网络结构的方法: 使用Netscope在线可视化 使用Caffe提供的draw_net.py 本文将就这两种方法加以介绍 1. Netscope:支持Caffe的神经网络结构在线可视化工具 Netscope是个支持prototxt格式描述的神经网络结构的在线可视工具,网址:  http://ethereon.github.io/netscope/quickstart.html  它可以用来可

[工具篇]eclipse 中设置 Java/JSP/JS/HTML/CSS 智能提示

Visual Studio 2010 中的智能提示很好用,在eclipse中是否也可以通过设置使得java代码文件.jsp文件.html文件.css文件.js文件时也能有这样方便的智能提示呢?应该是有的: 1.设置java代码智能提示 1)打开eclipse→Windows→Preferences→Java→Editor→Content Assist 2)修改Auto Activation triggers for java的值为:zjava   点击apply按钮.(zjava主要是用在后面替

物联网探步--工具篇之安装使用Qwtpolat

版权声明 该文章原创于Qter开源社区(www.qter.org),作者lxdlbs371,转载请注明出处! 简介 Qwtpolat是qwt的扩展,用来绘制极坐标系.极坐标系(polar coordinates)是指在平面内由极点.极轴和极径组成的坐标系.在平面上取定一点O,称为极点.从O出发引一条射线Ox,称为极轴.再取定一个长度单位,通常规定角度取逆时针方向为正.这样,平面上任一点P的位置就可以用线段OP的长度ρ以及从Ox到OP的角度θ来确定,有序数对(ρ,θ)就称为P点的极坐标,记为P(ρ

物联网探步--工具篇之安装使用qwtplot3d

版权声明 该文章原创于Qter开源社区(www.qter.org),作者lxdlbs371,转载请注明出处! 简介 qwtplot3d也是qwt的扩展,用来绘制三维模型图,在机械制造.遥感测绘和模型分析等领域中作用相当广泛. 此文是承接物联网探步--工具篇之安装QWT一文的,请先看此文. 实践 3.1:打开D:\qwt\MinGW\qwtplot3d\qwtplot3d.pro文件,在qwt3d_function.cpp文件中添加#include "stdio.h"头文件. 3.2:在