首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >字符串+ RandBetween() VBA的问题

字符串+ RandBetween() VBA的问题
EN

Stack Overflow用户
提问于 2017-12-05 12:29:58
回答 3查看 94关注 0票数 0
代码语言:javascript
复制
For i = i To nr_commercial
    Cells(i, 1) = commercial & RandBetween(1, 6)
Next i

大家好-我有上面的,但我不能解决它。它每次都返回一个编译器错误。我很难把一根线加一个公式放在一起。

commercial被定义为字符串

我甚至试过

代码语言:javascript
复制
Cells(i, 1) = commercial & = Randbetween(1,6)

它返回错误,表示期望表达式。这两者之间有什么不对的地方吗?

我需要在单元格中输出,例如:

代码语言:javascript
复制
commercial-1
commercial-5
commercial-3
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-12-05 12:36:18

尝试:

代码语言:javascript
复制
Application.WorksheetFunction.RANDBETWEEN(1,6)

例如:

代码语言:javascript
复制
Sub qwerty()
    Dim nr_commercial As Long, commercial As String

    nr_commercial = 10
    commercial = "whatever"
    For i = 1 To nr_commercial
        Cells(i, 1) = commercial & Application.WorksheetFunction.RandBetween(1, 6)
    Next i
End Sub

(还修正了循环索引)

票数 1
EN

Stack Overflow用户

发布于 2017-12-05 12:37:33

尝尝这个

代码语言:javascript
复制
For i = i To nr_commercial
  Cells(i, 1) = "commercial-" & Application.WorksheetFunction.RANDBETWEEN(1,6)
Next i

编辑:Application.WorksheetFunction.RANDBETWEEN(1,6)是要使用的正确公式

此外,在代码中使用Cells、尝试使用SheetWorksheet也是不可取的。

票数 0
EN

Stack Overflow用户

发布于 2017-12-05 14:12:30

我认为您的问题是您使用的是For i = i To nr_commercial,这意味着每次迭代都会更改"For 1=1 to nr_commercial“和"2 =2 to nr_commercial”,这是没有意义的。它应该是For i = 1 to nr_commercial或任何您想要开始的单元格,可能不是在第一个单元格中,因为您可能有标题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47653676

复制
相关文章

相似问题

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