Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 5110|回复: 10

[已解决]多条件VBA代码求助

[复制链接]
发表于 2014-6-19 11:10 | 显示全部楼层 |阅读模式
谢谢高手帮忙解决!刚才疏漏了一个条件
最佳答案
2014-6-19 11:44
本帖最后由 qh8600 于 2014-6-19 11:46 编辑
  1. Private Sub CommandButton1_Click()
  2.     Dim ar, i
  3.     ar = Range("a1:d" & Range("a1048576").End(3).Row)
  4.     For i = 2 To UBound(ar)
  5.         If ar(i, 2) = 6 Then
  6.             If ar(i, 3) < 16 Then
  7.                 ar(i, 4) = "短料"
  8.             ElseIf ar(i, 3) < 21 Then
  9.                 ar(i, 4) = "常规料"
  10.             Else
  11.                 ar(i, 4) = "长料"
  12.             End If
  13.         ElseIf ar(i, 2) = 8 Then
  14.             If ar(i, 3) < 20 Then
  15.                 ar(i, 4) = "短料"
  16.             ElseIf ar(i, 3) < 41 Then
  17.                 ar(i, 4) = "常规料"
  18.             Else
  19.                 ar(i, 4) = "长料"
  20.             End If
  21.         End If
  22.     Next
  23.     Range("a1").Resize(UBound(ar), UBound(ar, 2)) = ar
  24. End Sub
复制代码
IF语句双条件求助.rar (19.3 KB, 下载次数: 22)

IF语句双条件求助.zip

9.24 KB, 下载次数: 8

excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2014-6-19 11:44 | 显示全部楼层    本楼为最佳答案   
本帖最后由 qh8600 于 2014-6-19 11:46 编辑
  1. Private Sub CommandButton1_Click()
  2.     Dim ar, i
  3.     ar = Range("a1:d" & Range("a1048576").End(3).Row)
  4.     For i = 2 To UBound(ar)
  5.         If ar(i, 2) = 6 Then
  6.             If ar(i, 3) < 16 Then
  7.                 ar(i, 4) = "短料"
  8.             ElseIf ar(i, 3) < 21 Then
  9.                 ar(i, 4) = "常规料"
  10.             Else
  11.                 ar(i, 4) = "长料"
  12.             End If
  13.         ElseIf ar(i, 2) = 8 Then
  14.             If ar(i, 3) < 20 Then
  15.                 ar(i, 4) = "短料"
  16.             ElseIf ar(i, 3) < 41 Then
  17.                 ar(i, 4) = "常规料"
  18.             Else
  19.                 ar(i, 4) = "长料"
  20.             End If
  21.         End If
  22.     Next
  23.     Range("a1").Resize(UBound(ar), UBound(ar, 2)) = ar
  24. End Sub
复制代码
IF语句双条件求助.rar (19.3 KB, 下载次数: 22)
回复

使用道具 举报

 楼主| 发表于 2014-6-19 11:56 | 显示全部楼层
回复

使用道具 举报

发表于 2014-6-19 14:08 | 显示全部楼层
Range("a1048576").End(3).Row这一句是什么意思呢
回复

使用道具 举报

发表于 2014-6-19 14:11 | 显示全部楼层
为什么是.end(3)呢
回复

使用道具 举报

发表于 2014-6-19 14:21 | 显示全部楼层
end(3)与end(xlup)区别在哪呢

评分

参与人数 1 +6 收起 理由
ghostjiao + 6 好热爱学习!这两个是完全一样的,用xlup更.

查看全部评分

回复

使用道具 举报

发表于 2014-6-19 14:28 | 显示全部楼层
qh8600 发表于 2014-6-19 11:44

为什么是.end(3)呢,与end(xlup)区别在哪呢?

点评

一样的,3写起来简单,哇咔咔  发表于 2014-6-19 15:05
回复

使用道具 举报

发表于 2014-6-19 15:03 | 显示全部楼层
本帖最后由 qh8600 于 2014-6-19 15:10 编辑
含月化烛 发表于 2014-6-19 14:28
为什么是.end(3)呢,与end(xlup)区别在哪呢?

一样的,枚举 xlup枚举值是3
还可以写成  ar=Range("a1:d" & Cells(Rows.Count, 1).End(xlUp).Row)
回复

使用道具 举报

发表于 2014-6-19 15:18 | 显示全部楼层
qh8600 发表于 2014-6-19 15:03
一样的,枚举 xlup枚举值是3
还可以写成  ar=Range("a1:d" & Cells(Rows.Count, 1).End(xlUp).Row)

非常感谢,什么时候我的vba也能这么厉害,我现在还是菜鸟。。。。
回复

使用道具 举报

发表于 2014-6-19 15:19 | 显示全部楼层
含月化烛 发表于 2014-6-19 14:21
end(3)与end(xlup)区别在哪呢

非常感谢!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-6-1 03:20 , Processed in 0.254370 second(s), 11 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表