xmxmxm22 2023-03-18 17:17 采纳率: 0%
浏览 14

Offset带循环变量偏移问题

Offset为什么把i设置成0-4,第一次后会多跳两格,后面却不会?

Sub 测试()
For i = 0 To 4 * 3 Step 3
Sheet1.Range("AG5").Offset(0, i).Select
Sheet1.Range("AG5").Offset(0, i).UnMerge
Sheet1.Range("AG5").Offset(0, i).ClearContents
Sheet1.Range("AG5").Offset(0, i).Resize(, 3).Merge
Sheet1.Range("AG5").Offset(0, i) = i
Next
End Sub

img

把i设置成1-5却不会

Sub 测试()
For i = 1 To 5 * 3 Step 3
Sheet1.Range("AG5").Offset(0, i).Select
Sheet1.Range("AG5").Offset(0, i).UnMerge
Sheet1.Range("AG5").Offset(0, i).ClearContents
Sheet1.Range("AG5").Offset(0, i).Resize(, 3).Merge
Sheet1.Range("AG5").Offset(0, i) = i
Next
End Sub

img

  • 写回答

2条回答 默认 最新

  • MarkHan_ 2023-03-18 17:52
    关注

    该回答引用GPTᴼᴾᴱᴺᴬᴵ
    这是因为Offset方法的第二个参数表示的是偏移量,而不是列数。因此,在第一个循环中,第一次Offset(0, 0)是不会偏移的,第二次Offset(0, 3)是偏移3列,而第三次Offset(0, 6)是偏移了6列,导致跳过了两列。
    ·
    在第二个循环中,因为把i的初始值设为1,第一次Offset(0, 1)就会偏移一列,所以不会出现跳过两列的情况。

    评论

报告相同问题?

问题事件

  • 创建了问题 3月18日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度