excel中VBA的使用
遇到的问题
在工作中遇到了一点小小的问题,需要给我负责带的班级的同学们测试男生1000米,女生800米的成绩。表格是这样的:
| 序号 | 班级 | 姓名 | 性别 | 男1000、女800 | 成绩 |
| 1 | 1 | 张三 | 男 | 3.50 | |
| 2 | 1 | 李四 | 女 | 3.44 |
我们在录入完成绩后,需要按照一定的标准去给出学生成绩,标准是这样的:
需要我们根据每个学生的成绩,给出对应的分数。于是,我就计算了下我的工作量:每个人对应的需要给分数,总共需要给六个班 x 70 个人也就是差不多420个人给分数。那样的一个工作量,感觉还是比较累的。于是就想能不能写一个函数,自动实现给学生判分。本来感觉这个应该很简单,一个if函数很容易就可以解决了。
解决方案
后来我按照最初的想法实现了一版。函数是这么写的:(非源代码,类似代码)
=IF(D4<1,1," IF(D4<2,"这是2","IF(D4<3,"这是3","IF(D4<4,"这是4","IF(D4<5,"这是5","IF(D4<6,"这是6","IF(D4<7,"这是7","IF(D4<8,"这是8","IF(D4<9,"这是9","大于9")")")")")")")")")
后来发现这样写没有办法实现,excel会报错,报错如下:
后来查了下,是因为excel中if函数只能嵌套七层,再多的话就会出现刚才的问题。那么问题还是要解决啊,怎么办呢?
优化
经过检查,发现如下解决方案:将if用& 链接,代码如下:
=IF(D13<1,1,"")&IF(D13<2,"这是2","")&IF(D13<3,"这是3","")&IF(D13<4,"这是4","")&IF(D13<5,"这是5","")&IF(D13<6,"这是6","")&IF(D13<7,"这是7","")&IF(D13<8,"这是8","")&IF(D13<9,"这是9","")&IF(D13<10,"这是10","")&IF(D13<11,"这11","")&IF(D13<12,"大于11","")
可以继续&连接下去
但是发现这样并不能解决问题,会出现如下的显示:
使用宏vba
后来,就考虑是不是用下vba。然后就查了相关的信息。发现vba实现的话其实很简单。按Alt+F11键后,出现如下
在其中写入代码如下:
Sub Tests()
Dim rng As Range, i As Integer
F2 = "成绩" '标题
For Each rng In Range([e3], Cells(Rows.Count, 5).End(xlUp))
'遍历成绩
If rng.Offset(0, -1) = "女" Then
'按成绩给分
If rng < 3.35 Then
rng.Offset(0, 1) = 100
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 93
ElseIf rng < 3.42 Then
rng.Offset(0, 1) = 86
ElseIf rng < 3.46 Then
rng.Offset(0, 1) = 80
ElseIf rng < 3.5 Then
rng.Offset(0, 1) = 73
ElseIf rng < 3.54 Then
rng.Offset(0, 1) = 67
ElseIf rng < 3.58 Then
rng.Offset(0, 1) = 60
ElseIf rng < 4.03 Then
rng.Offset(0, 1) = 53
ElseIf rng < 4.08 Then
rng.Offset(0, 1) = 47
ElseIf rng < 4.09 Then
rng.Offset(0, 1) = 40
ElseIf rng >= 4.09 Then
rng.Offset(0, 1) = "不及格"
End If
ElseIf rng.Offset(0, -1) = "男" Then
If rng < 3.35 Then
rng.Offset(0, 1) = 100
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 93
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 86
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 80
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 73
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 67
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 60
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 53
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 47
ElseIf rng < 3.38 Then
rng.Offset(0, 1) = 40
ElseIf rng >= 4.09 Then
rng.Offset(0, 1) = "不及格"
End If
End If
If rng = "" Then
rng.Offset(0, 1) = ""
End If
Next rng End Sub
在excel中将成绩录入完后,点开宏,选中其中的tests (刚才写的函数名称)然后单击执行。如图所示:
单击执行,然后得出成绩。如图所示:
自动算分实现。不过目前只能实现一个表格,要想每个表格都实现,那么就需要写在vba的模块中。具体深入的写法,有一本书推荐给大家《别怕,Excel VBA其实很简单》这本书上有详细的介绍。
http://download.csdn.net/detail/u013049248/9513670
excel中VBA的使用的更多相关文章
- excel中vba将excel中数字和图表输出到word中
参考:https://wenku.baidu.com/view/6c60420ecc175527072208af.html 比如将选区变为图片保存到桌面: Sub 将选区转为图片存到桌面() Dim ...
- Excel中VBA进行插入列、格式化、排序
在数据分析中经常需要对数据进行排序.排名,观察指标排名变化情况,手工处理的话不是太困难,但经常使用,还是编写宏比较方便. 宏命令比较简单,不多解释,只说一下注意事项: 1.有合并单元格,比如列.行合并 ...
- Excel中VBA 连接 数据库 方法- 摘自网络
Sub GetData() Dim strConn As String, strSQL As String Dim conn As ADODB.Connection Dim ds As ADODB.R ...
- excel中VBA对多个文件的操作
添加引用 "Scripting.FileSystemObject" (Microsoft Scripting Runtime) '用于操作文件.目录 Sub 数据整理部分() ' ...
- excel中vba求摩尔圆包线
Dim f As Double, f1 As Double, f2 As Double, df As Double, oxy() As Double, R() As Double, k As Doub ...
- 如何在Excel中通过VBA快速查找多列重复的值
今天项目组的一个同事问我如何快速的找到一个Excel中第3列和第5列的值完全重复的值,我想了想虽然Excel中自带查找重复值的功能,但是好像只能对同一列进行比较,所以就写了一个VBA进行处理,VBA非 ...
- 用VBA计算WPS 表格ET EXCEL中的行数和列数的多重方法
用VBA计算WPS 表格ET EXCEL中的行数和列数 每种方法中上面的是Excel的行数,下面的是Excel的列数. 方法1: ActiveSheet.UsedRange.Rows.Count Ac ...
- Excel中的宏--VBA的简单例子
第一步:点击录制宏 第二步:填写宏的方法名 第三步:进行一系列的操作之后,关闭宏 第四步:根据自己的需要查看,修改宏 第六步:保存,一般是另存为,后缀名为.xlsm,否则宏语言不能保存. 到此为止恭喜 ...
- VBA在Excel中的应用(一):改变符合条件单元格的背景颜色
在使用excel处理数据的时候,为了能更清晰的标示出满足特定条件的单元格,对单元格添加背景色是不错的选择.手工处理的方式简单快捷,但是当遇到大批量数据,就会特别的费时费力,而且不讨好(容易出错).通过 ...
随机推荐
- linux 驱动入门6
看/sys目录经常看到bus device driver class. 这也是网上大量说的驱动驱动模型.这些的关系得熟悉得明白吧.是的.今天我先不整他们的关系.先逐个击破,然后再统一来理清楚他们之间的 ...
- Salesforce开发者学习笔记之二:Salesforce开发平台应用场景
Salesforce作为一个全方位的CRM系统可以应用于企业中的各个不同部门以取代手工的,耗时的以及低效的业务流程,例如 基于报表的数据管理和分析 基于电子邮件的协同合作 本地的文件共享 各种手工操作 ...
- linux ssl 双向认证
一,首先切换到apache目录下,创建一个CA文件夹 sudo mkdir CA sudo chmod 777 CA 二,然后进去CA文件夹 cp CA 三,创建其它文件 mkdir demoCA m ...
- 获取linq生成的sql语句
命名空间:using System.Data.Objects; var query = db.TxtRes.Join(db.LangRes, a => new { id1 = a.ResID, ...
- 一个异步任务接收两个url下载两个图片
有两个url,一个是下载用户头像的url,一个是下载用户上传图片的url,想要用一个异步任务同时下载这两个图片. 程序的下载任务是这么执行的,先接受url参数,然后调用 imgUrls = infoP ...
- eclipse中集成svn maven开发手册---合并主干
如图,代码提交分支之后 右键,项目,切换到主干版本 切换回主干版本后: 更新主干版本 合并 选择merge a range of revisions,点击next 录入要合并的分支版本的路径.此处的s ...
- iOS + UIWebView 实践
1. 调用java script 现在只能实现弹出窗口 [self.m_webView stringByEvaluatingJavaScriptFromString:@"alert(1)&q ...
- ios framework 开发 之 实战 一,合并失败了
保证public 文件目录独立 在 XCode 7 中,这一条已经自动实现了 Build Settings>Public Headers Folder Path "$(PROJECT_ ...
- UVa 10057 - A mid-summer night's dream
题目大意:给n个数,找一个数A使得A与这n个数的差的绝对值最小.输出A最小的可能值,n个数中满足A的性质的数的个数以及满足A性质的不同的数的个数(不必从这n个数中挑选). 看见绝对值就想到了数轴上点之 ...
- Nginx中的信号量(信号控制)