zl程序教程

您现在的位置是:首页 >  后端

当前栏目

VBA转VB.Net VSTO学习记录-3

Net学习 记录 vba vb VSTO
2023-06-13 09:14:17 时间

yhd-VBA转VB.NetVSTO学习记录-3

【目标】想搞个插件

【学习内容】

本次学习内容有VB.net数组、列表、字典

学习它们相关的属性与方法

以下学习在VSTO外接程序中测试通过

【目录】

数据类型

—维数组输出二维数据输出字典输出

读取单元格

读取区域读取一行中A1:J1读取你选中区域

【代码】

【放上代码,方便复制、粘贴学习之用】

'一维数组写入单位元格测试,Ubound上标界,Length长度
    Private Sub Button4_Click(sender As Object, e As RibbonControlEventArgs) Handles Button4.Click
        Dim Data1Arr1() As Integer = {1, 2, 3}
        Dim Ub As Integer = UBound(Data1Arr1)
        Dim Len As Integer = Data1Arr1.Length
        xlapp.ActiveSheet.cells.clear()
        MsgBox("数组上标界:" + Ub.ToString() + vbCrLf + "数组长度" + Len.ToString())
        '输出-1,有问题
        xlapp.ActiveSheet.Range("A1:D1").Value = Data1Arr1
'输出-2,有问题
        xlapp.ActiveSheet.cells(2, 1).value = Data1Arr1
        '输出-3,OK
        xlapp.ActiveCell.Resize(1, Len).Value = Data1Arr1
'输出-4,OK
        xlapp.ActiveSheet.cells(10, 1).Resize(Len, 1).value = xlapp.WorksheetFunction.Transpose(Data1Arr1)
    End Sub
    '二维数据输出,获取数组中指定维度最后一个元素的索引GetUpperBound(0)行UBound(Data2Arr1, 1) + 1,GetUpperBound(1)列UBound(Data2Arr1, 2) + 1
Private Sub Button5_Click(sender As Object, e As RibbonControlEventArgs) Handles Button5.Click
        Dim Data2Arr1(2, 3) As String
For i As Integer = 0 To 2
For j As Integer = 0 To 3
                Data2Arr1(i, j) = i.ToString() + "行" + j.ToString() + "列"
            Next
        Next
        Dim myRow As Integer = Data2Arr1.GetUpperBound(0) + 1
        Dim myCol As Integer = Data2Arr1.GetUpperBound(1) + 1
        Dim myRow2 As Integer = UBound(Data2Arr1, 1) + 1
        Dim myCol2 As Integer = UBound(Data2Arr1, 2) + 1
        xlapp.ActiveSheet.cells.clear()
        MsgBox("获取数组中指定维度最后一个元素的索引GetUpperBound(0)+1=" + myRow.ToString() + vbCrLf + "UBound(Data2Arr1, 1) + 1=" + myRow2.ToString() + vbCrLf + "GetUpperBound(1)=" + myCol.ToString() + vbCrLf + myCol2.ToString())
'输出方式一,OK
        xlapp.ActiveCell.Resize(myRow, myCol).Value = Data2Arr1
        '输出方式二,有问题
        xlapp.ActiveSheet.cells(5, 5).Value = Data2Arr1
'输出方式三,OK
        For i As Integer = Data2Arr1.GetLowerBound(0) To Data2Arr1.GetUpperBound(0)
            For j As Integer = Data2Arr1.GetLowerBound(1) To Data2Arr1.GetUpperBound(1)
                xlapp.ActiveSheet.cells(10, 10).Offset(i, j) = Data2Arr1(i, j)
            Next
        Next
    End Sub
    '读取区域
Private Sub Button6_Click(sender As Object, e As RibbonControlEventArgs) Handles Button6.Click
'Dim star_arr(,) As Integer = {{1, 2, 3}, {4, 5, 6}}
        'xlapp.ActiveSheet.Cells(1, 1).Resize(2, 3).value = star_arr
        Dim Read_arr As Array = xlapp.ActiveSheet.Range("A1:C3").value
        MsgBox(UBound(Read_arr, 1))
        MsgBox(UBound(Read_arr, 2))
        MsgBox(Read_arr(1, 2))
    End Sub
'字典输出
    Private Sub Button8_Click(sender As Object, e As RibbonControlEventArgs) Handles Button8.Click
        Dim Dic As New Dictionary(Of String, Integer)
        Dic.Add("Dot", 20)
        Dic.Add("Net", 1)
        Dic.Add("Perls", 10)
        Dic.Add("Visual", -1)
        Dim DicList As New List(Of String)(Dic.Keys)
        Dim i As Integer
        '下面
        MsgBox("下面准备遍历列表,输出到当前单元格")
For Each li As String In DicList
            xlapp.ActiveCell.Offset(i, 0).Value = li
            i = i + 1
        Next
'错误的输出方式
        'xlapp.ActiveSheet.cells(2, 5).Resize(1, Dic.Keys.Count).Value = DicList
        MsgBox("遍历Dic.keys")
For Each d As String In Dic.Keys
            MsgBox("字典输出" + vbCrLf + "key=" + d + vbCrLf + "item=" + Dic.Item(d).ToString())
        Next
'错误的输出方式
        'xlapp.ActiveSheet.cells(1, 5).Resize(1, Dic.Keys.Count).Value = Dic.kes
'字典keys 复制到数组, 再输出到工作表
        MsgBox("字典.keys.CopyTo() 复制到数组, 再输出到工作表")
        Dim DicArr(Dic.Keys.Count) As String
        Dic.Keys.CopyTo(DicArr, 0)
        xlapp.ActiveSheet.cells(1, 5).Resize(1, Dic.Keys.Count).Value = DicArr
        Dim DicArrList As New List(Of Integer)
        For Each d2 As String In Dic.Keys
            DicArrList.Add(Dic.Item(d2))
        Next
        MsgBox(DicArrList.Count)
    End Sub
    '读取一行中A1:J1
Private Sub Button7_Click(sender As Object, e As RibbonControlEventArgs) Handles Button7.Click
        Dim A1J1 As Excel.Range = xlapp.ActiveSheet.Range("A1:J1")
        With A1J1
            .Borders.LineStyle = 1
            .Interior.Color = 65535
'.NumberFormatLocal = "@"
        End With
        MsgBox("单元格总数:" + A1J1.Count.ToString())
        If xlapp.WorksheetFunction.CountA(A1J1) <> 0 Then
            Dim Read_arr As Array = A1J1.Value
            MsgBox("行数:" + UBound(Read_arr, 1).ToString() + "列数:" + UBound(Read_arr, 2).ToString())
            For i As Integer = LBound(Read_arr, 1) To UBound(Read_arr, 1)
                For j As Integer = LBound(Read_arr, 2) To UBound(Read_arr, 2)
                    MsgBox(Prompt:=Read_arr(i, j), Title:=i.ToString() + "," + j.ToString())
                Next
            Next
        Else
            MsgBox("A1:J1全为空,将要退出")
            Exit Sub
        End If
    End Sub
    '读取你选中区域,再赋值给数组,再在O1后显示出信息
Private Sub Button9_Click(sender As Object, e As RibbonControlEventArgs) Handles Button9.Click
        Dim myselection As Excel.Range = xlapp.Selection
        Dim myselArr As Object = myselection.Value
        With xlapp.ActiveSheet.cells(1, 15)
            .resize(100, 100).clearcontents
            .value = "你选中区域是:" + myselection.Address
            .offset(1, 0).value = "单元格总数:" + myselection.Count.ToString()
            .offset(2, 0).value = "数组行数:" + UBound(myselArr, 1).ToString() + "数组列数:" + UBound(myselArr, 2).ToString()
'把数组输出
            For i As Integer = LBound(myselArr, 1) To UBound(myselArr, 1)
                For j As Integer = LBound(myselArr, 2) To UBound(myselArr, 2)
                    .offset(2 + i, j).value = myselArr(i, j)
                Next
            Next
        End With
    End Sub