VBA /宏代码获取文本框的值

时间:2016-03-18 00:58:28

标签: excel vba textbox getvalue

Sub CopyRandomRows()

 Windows("sample rnd.xlsm").Activate
    Rows("1:1").Select
    Selection.Copy
    Application.CutCopyMode = False
    Selection.Copy
    Windows("rnd sample draft.xlsm").Activate
    Sheets("Random Sample").Select
    Rows("1:1").Select
    ActiveSheet.Paste


  Dim source As Range, target As Range, randCount&, data(), value, r&, rr&, c&


  Set source = Workbooks("sample rnd.xlsm").Worksheets("Sheet1").Range("A2:L5215")

  Set target = Workbooks("rnd sample draft.xlsm").Worksheets("Random Sample").Range("A2")

  randCount = 5

  data = source.value


  For r = 1 To randCount
    rr = 1 + Math.Round(VBA.rnd * (UBound(data) - 1))
    For c = 1 To UBound(data, 2)
      value = data(r, c)
      data(r, c) = data(rr, c)
      data(rr, c) = value
    Next
  Next


  target.Resize(randCount, UBound(data, 2)) = data

End Sub

这是我的代码。我的问题是,如果我更改代码randCount = 5,我只能更改我想要的数据数量。我希望能够使用我的TextBox并使用它来定义要获取的数据量。我尝试了randCound = TextBox1.valuerandCount = TextBox1.Text,但似乎没有用。我错过了什么?我如何让它工作。提前谢谢

2 个答案:

答案 0 :(得分:2)

如果TextBox1位于名为Main的工作表上,则可以使用:

Worksheets("Main").TextBox1.Value

更好的是,您可以为表单CodeName提供shtMain,然后使用

shtMain.TextBox1.Value

最后,你也可以通过形状集合到达文本框(但上面的方法更可取)......

Worksheets("Main").Shapes("TextBox1").OLEFormat.Object.Object.Value

答案 1 :(得分:0)

您应该可以使用foo = InputBox("bar")

如果您从UserForm获取它,那么它将是foo = UserForm1.TextBox1.Value