在VBA中Range("a1").End(xlDown).Row

在VBA中Range("a1").End(xlDown).Row和Range("a1").End(xlup).Row什么区别啊还有在VBA中Range("a1").End... 在VBA中Range("a1").End(xlDown).Row和Range("a1").End(xlup).Row什么区别啊
还有在VBA中Range("a1").End(xltoright).column什么意思啊谢谢啦
展开
 我来答
小无谈旅游百科
高粉答主

2020-06-16 · 每个回答都超有意思的
知道小有建树答主
回答量:824
采纳率:98%
帮助的人:19.2万
展开全部

如果你在循环语句中使用它,很容易出错,因为值没有改变,

所以要放到循环语句前,取得最后一行的值,

另外,使用Range("a1").End(xlDown).Row如果A列第一行下面全为空,

则得到表的最后一行65536,容易出错,

建议使用Range("a65536").End(xlUp).Row

Suba()

DimiAsLong

DimrAsLong

r=Range("a1").End(xlDown).Row

Fori=1To10

r=r+1

Cells(r,1)=i

Nexti

EndSub

扩展资料:

注意事项:

以C语言为例,for循环的一般形式为:

(语句1;语句2;3)声明

要执行,执行语句1一次(注意只有一次)

然后判断表述二是否正确

1.如果建立了循环体,则执行语句3。返回语句2来确定条件是否为真?语句3在循环体建立之后执行,直到没有建立循环体为止

2.如果语句2不为真,则不会执行循环体,也不会执行语句3。

010uvbu506
推荐于2018-02-28 · TA获得超过296个赞
知道答主
回答量:552
采纳率:0%
帮助的人:391万
展开全部
在循环语句内使用的话,很容易出错,因为其值不会变化,
所以要放到循环语句前,取得最后一行的值,
另外,使用Range("a1").End(xlDown).Row如果A列第一行下面全为空,
则得到表的最后一行65536,容易出错,
建议使用Range("a65536").End(xlUp).Row
Sub a()
Dim i As Long
Dim r As Long
r = Range("a1").End(xlDown).Row
For i = 1 To 10
r = r + 1
Cells(r, 1) = i
Next i
End Sub
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
808tzty707
2011-08-25 · TA获得超过221个赞
知道答主
回答量:519
采纳率:100%
帮助的人:312万
展开全部
在循环语句内使用的话,很容易出错,因为其值不会变化,
所以要放到循环语句前,取得最后一行的值,
另外,使用Range("a1").End(xlDown).Row如果A列第一行下面全为空,
则得到表的最后一行65536,容易出错,
建议使用Range("a65536").End(xlUp).Row
Sub a()
Dim i As Long
Dim r As Long
r = Range("a1").End(xlDown).Row
For i = 1 To 10
r = r + 1
Cells(r, 1) = i
Next i
End Sub
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式