VBA小记
要放假了,可是我们,我还是煎熬!
最让人不爽的是媳妇也需要加班加点的完成一些看起来很EASY的事:
统计数据,把几个表合并……
EXCEL本人还是懂得一点点的(我不想说我是学计算机的,我怕给学计算机的同志们丢脸)
早答应媳妇要给做一个程序,可以方便她做表的,可是一直没有做,
这里给媳妇道个歉!媳妇,我错了:)
那就做吧,具体怎么做就不再说,这里主要是把用到的一些程序做一个记录,以防以后还会用到。
代码有点不堪,高手请自行飘过~~~~~~~~~~
'点击开始计算,根据输入的表名,行,列
'简单的判断下有没有输入数据
'没有做严格的正则的匹配判断
Private Sub beginSum_Click()
Dim sheetName As String
Dim beginRow As Integer
Dim endRow As Integer
Dim beginCol As Integer
Dim endCol As Integer
Dim sumCol As Integer sheetName = tbSheetName.Text
beginRow = tbBeginRow.Text
endRow = tbEndRow.Text
beginCol = tbBeginCol.Text
endCol = tbEndCol.Text
sumCol = tbSumCol.Text If Len(sheetName) = Then
MsgBox "请输入正确的Sheet名称"
Exit Sub
ElseIf Not (IsNumeric(beginRow) And IsNumeric(endRow) And IsNumeric(endRow) And IsNumeric(beginCol) And IsNumeric(endCol) And IsNumeric(sumCol)) Then
MsgBox "请输入正确的行或列数"
Exit Sub
End If Call CountPersonYear(sheetName, beginRow, endRow, beginCol, endCol, sumCol)
MsgBox "计算完成!" End Sub
'计算过程--有点复杂,先每行求和,再把同一个人的N个月的数据再求和,再加上某个月的前N(2)项
'当然,前提是在每个人的信息后面要插入一个空行 见 InsertRow()
'然后把这个总数写入到另一个固定列的表中,见WriteToTable()
Sub CountPersonYear(sheetName As String, beginRow As Integer, endRow As Integer, beginCol As Integer, endCol As Integer, sumCol As Integer)
Dim personBeginRow As Integer
Dim mySum As Double
Dim bigMonth As Integer
Dim curMonth As Integer Dim i As Integer
Dim j As Integer Dim myWorkBook As Workbook
Dim mySheet As Worksheet Set myWorkBook = Application.ActiveWorkbook
Set mySheet = myWorkBook.Sheets(sheetName) personBeginRow = beginRow
bigMonth = mySheet.Cells(beginRow, )
'mySum = 0#
endRow = endRow + For i = beginRow To endRow
curMonth = mySheet.Cells(i, )
If (Len(curMonth) <> And curMonth <> ) Then
For j = beginCol To endCol
mySum = mySum + mySheet.Cells(i, j)
Next
mySheet.Cells(i, sumCol) = mySum
mySum = CDbl()
ElseIf (mySheet.Cells(i - , ) <> And Len(mySheet.Cells(i - , )) <> ) Then For j = personBeginRow To i -
mySum = mySum + CDbl(mySheet.Cells(j, sumCol))
Next mySheet.Cells(i, sumCol) = mySum + CDbl(mySheet.Cells(personBeginRow, )) + CDbl(mySheet.Cells(personBeginRow, )) Call WriteToTable("SheetSum", mySheet.Cells(personBeginRow, ), mySheet.Cells(personBeginRow, ), CStr(mySheet.Cells(personBeginRow, )), mySheet.Cells(i, sumCol)) mySum = CDbl() For j = i To endRow
If (mySheet.Cells(j, ) <> And (mySheet.Cells(j, )) <> ) Then
personBeginRow = j
bigMonth = mySheet.Cells(j, )
Exit For
End If
Next
End If
Next
End Sub '把计算后的结果写入另一个表中
Sub WriteToTable(sheetName As String, strName As String, strCardID As String, strYear As String, all As Double) Dim aSheet As Worksheet
Dim i As Integer
Dim j As Integer
Dim curRow As Double
Dim flag As Boolean flag = False Set aSheet = Application.ActiveWorkbook.Sheets(sheetName) 'curRow = aSheet.Cells(Rows.Count, 1).End(1).Row
'需要表中的数据没有用过的,要整行的删除,这样保证数据的连续性,不能只删除数据内容
curRow = aSheet.UsedRange.Rows.Count
For i = To curRow
If (aSheet.Cells(i, ) = strCardID) Then
For j = To
If CStr(aSheet.Cells(, j)) = strYear Then
aSheet.Cells(i, j) = all
flag = True
Exit For
End If
Next
End If
Next
If Not flag Then
curRow = curRow +
aSheet.Cells(curRow, ) = strName
aSheet.Cells(curRow, ) = strCardID
aSheet.Cells(curRow, ) = curRow
For j = To
If CStr(aSheet.Cells(, j)) = strYear Then
aSheet.Cells(curRow, j) = all
Exit For
End If
Next
End If
End Sub
'在每个人的信息后插入一空行,用于做总和
'插入是以个人的身份证是不是一样来判断的
'这里面要数据是连续的,如果下一个为空则认为是身份证号不一样会插入一空行
Sub InsertRow(sheetName As String, personCol As Integer)
Dim rng As Range
Dim personRow As String
Dim r As Integer
Dim n As Integer
Dim lastRow As Integer Dim mySheet As Worksheet
Set mySheet = Application.ActiveWorkbook.Sheets(sheetName) '第三列,即人名列最大的单元格数
lastRow = mySheet.Cells(Rows.Count, ).End().Row
For r = lastRow - To Step -
If (mySheet.Cells(r, personCol) <> mySheet.Cells(r - , personCol)) Then
mySheet.Cells(r, ).EntireRow.Insert
End If
'For n = 1 To Cells(r - 1, 1).Value
' Cells(r, 1).EntireRow.Insert
'Next n
Next r
End Sub
VBA小记的更多相关文章
- [原]Paste.deploy 与 WSGI, keystone 小记
Paste.deploy 与 WSGI, keystone 小记 名词解释: Paste.deploy 是一个WSGI工具包,用于更方便的管理WSGI应用, 可以通过配置文件,将WSGI应用加载起来. ...
- VBA 格式化字符串 - Format大全
VBA 格式化字符串 VBA 的 Format 函数与工作表函数 TEXT 用法基本相同,但功能更加强大,许多格式只能用于VBA 的 Format 函数,而不能用于工作表函数 TEXT ,以下是本人归 ...
- MySql 小记
MySql 简单 小记 以备查看 1.sql概述 1.什么是sql? 2.sql发展过程? 3.sql标准与方言的关系? 4.常用数据库? 5.MySql数据库安装? 2.关键概念 表结构----- ...
- VBA学习
1. Range / Cells / Columns / Rows 2. 绝对引用 $F$13 / 相对引用 F13 公式所在单元格的被复制到其他位置时,绝对引用不变 3. VLookup / NLo ...
- VBA学习思路
打算花两三天学习VBA的基础,学习资料为<别怕,VBA其实很简单>,为了快速学习,先了解大致框架,后续再深入学习各种属性.方法和技巧. 1.VBA编程环境基本操作,手工操作,熟悉即可 2. ...
- VBA笔记(三)——常用对象
VBA实际上就是操作Excel,把Excel进行拆解,划分多层对象,由顶至下为(也可以说是层层包裹): Application:代表Excel程序本性,之后我们操作对象都在它之下,因为是唯一且至高点, ...
- VBA中使用计时器的两种方法
'================================ ' VBA采用Application.OnTime实现计时器 ' ' http://www.cnhup.com '========= ...
- Git小记
Git简~介 Git是一个分布式版本控制系统,其他的版本控制系统我只用过SVN,但用的时间不长.大家都知道,分布式的好处多多,而且分布式已经包含了集中式的几乎所有功能.Linus创造Git的传奇经历就 ...
- 广州PostgreSQL用户会技术交流会小记 2015-9-19
广州PostgreSQL用户会技术交流会小记 2015-9-19 今天去了广州PostgreSQL用户会组织的技术交流会 分别有两个session 第一个讲师介绍了他公司使用PostgreSQL-X2 ...
随机推荐
- 如何判断一个for循环执行完毕
在外面一个变量a=arr.leng; 然后就是进行for循环, 在for循环下面进行判断,因为如果结束那么i的值就会>=a;if条件成立的话,可以在里面进行循环完毕要做的操作.
- 蓝桥杯 2014本科C++ B组 奇怪的分式 暴力枚举
蓝桥杯 枚举 奇怪的分式 标题:奇怪的分式 上小学的时候,小明经常自己发明新算法.一次,老师出的题目是: 1/4 乘以 8/5 小明居然把分子拼接在一起,分母拼接在一起,答案是:18/45 (参见图1 ...
- python使用ftplib做ftp操作
ftplib是 Python的内置的一个标准模块,它提供了极强大的对FTP服务器的操作,通过它我们可以连接并操作FTP服务端,开始练习: 一.导入模块并进行连接 >>> from f ...
- 基于粒子群优化的无约束50维Rosenbrock函数求解
基于粒子群优化的无约束50维Rosenbrock函数求解 一.问题重述 无约束50维的Rosenbrock函数可以描述如下: 其中, 0 要求按PSO算法思想设计一个该问题的求解算法. Rosenbr ...
- CV_Assert
转:http://blog.csdn.net/ding977921830/article/details/46376847 Checks a condition at runtime and thro ...
- Hadoop2 使用 YARN 运行 MapReduce 的过程源码分析
Hadoop 使用 YARN 运行 MapReduce 的过程如下图所示: 总共分为11步. 这里以 WordCount 为例, 我们在客户端终端提交作业: # 把本地的 /home/hadoop/t ...
- 一个IP绑定多个域名的实现方法
方案一: 文字叙述: 具体步骤如下:比如讲apache服务器127.0.0.1 配置成 www.sohu.com 首先在http.conf文件中 做如下处理: ①关闭默认的 #DocumentRoot ...
- SqlServer2012——快照
1.数据库快照 优点: 维护历史数据以生成报表.由于数据库快照可提供数据库的静态视图,因而可以通过快照访问特定时间点的数据. 将查询实施在数据库的快照上,可以释放主体数据库上的资源. 数据库快照的限制 ...
- Unity2d 骨骼动画3:介绍Mecanim和脚本
http://bbs.9ria.com/thread-402710-1-1.html 在这个系列,我们将关注Unity引擎提供的基于骨骼动画工具.它的主要思想是为了把它应用到你自己的游戏来介绍和教基本 ...
- 浅谈C++中内存泄漏的检测
首先我们需要知道程序有没有内存泄露,然后定位到底是哪行代码出现内存泄露了,这样才能将其修复.最简单的方法当然是借助于专业的检测工具,比较有名如BoundsCheck,功能非常强大,相信做C++开发的人 ...