首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >两个工作表之间的For循环

两个工作表之间的For循环
EN

Stack Overflow用户
提问于 2019-07-09 20:44:54
回答 2查看 44关注 0票数 0

我运行一个run循环从一个工作表中复制值并将其粘贴到另一个工作表中时,遇到了RUn时间错误。这是我的代码;

代码语言:javascript
运行
复制
 Option Explicit

 Sub TeknikerData()

 Dim Lag As String
 Dim lr1 As long
 Dim lr2 As Long
 Dim i As Integer
 Dim j As Integer
 Dim wh1 As Worksheet
 Dim wh2 As Worksheet

 Set wh1 = Sheets("Data")
 Set wh2 = Sheets("Dashboard")
 lr1 = wh1.Cells(Rows.Count, 4).End(xlUp).Row


 Lag = wh2.Cells(12, 1).Value

 For i = 2 To lr1
 If wh1.Cells(i, 4) = Lag Then
 wh1.Range(Cells(i, 2), Cells(i, 2)).Copy
 wh2.Range("B50").End(xlUp).Offset(1, 0).PasteSpecial xlPasteFormulasAndNumberFormats



  End If

  Next i



  End Sub

我知道在运行循环时激活正确的工作表似乎有问题,但我无法解决这个问题

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-07-09 20:50:44

看起来您已经将for循环的上限声明为字符串而不是数字数据类型,如下所示。

代码语言:javascript
运行
复制
 Dim lr1 As String

应更改为

代码语言:javascript
运行
复制
Dim lr1 As Long

我也刚刚注意到

代码语言:javascript
运行
复制
wh1.Range(Cells(i, 2), Cells(i, 2)).Copy

应该是

代码语言:javascript
运行
复制
wh1.Range(wh1.Cells(i, 2), wh1.Cells(i, 2)).Copy
票数 2
EN

Stack Overflow用户

发布于 2019-07-09 20:48:21

您遇到的是哪一行错误?

你打算在for循环中使用j吗?

代码语言:javascript
运行
复制
wh1.Range(Cells(i, 2), Cells(i, 2)).Copy '<- are one of these i's supposed to be j?
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56952917

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档