Moh*_*ien 3 excel vba excel-formula
我有一个关于在我的工作表中的特定单元格内显示 Selection 值的问题。(我们现在称其为 J1)因此,如果用户拖动选择(通过鼠标)A1,A2,A3,A4。J1value 将显示"A1:A4",然后使用一些 VBA 代码连接这些单元格以显示由“;”分隔的单元格值。问题是,当用户选择不按顺序的单元格(通过按住 CTRL)时, Like A1,A5,A11。J1value 将"A1,A5,A11"在我连接时显示,它会给出“#VALUE”错误。
我们可以用单元格值替换这里的每个单元格引用吗?并按原样保留两者之间的“逗号”。然后我们可以用Subtitute逗号“;”
如果我的问题看起来有点无知,请见谅:)
我的选择代码:
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Dim rng As Range
Dim s As String
Set rng = Application.Selection
If rng.Count < 2 Then
Range("H1").Value = Cells(Target.Row, Target.Column).Value
Else
Range("H1").Value = rng.Address
End If
End Sub
Run Code Online (Sandbox Code Playgroud)
连接代码:
Function ConcatenateRange(ByVal cell_range As Range, _
Optional ByVal seperator As String) As String
Dim cell As Range
Dim lastrow
Dim choice
Dim lastrowmodified
Dim rangy
Dim newString As String
Dim cellArray As Variant
Dim i As Long, j As Long
cellArray = cell_range.Value
For i = 1 To UBound(cellArray, 1)
For j = 1 To UBound(cellArray, 2)
If Len(cellArray(i, j)) <> 0 Then
newString = newString & (seperator & cellArray(i, j)) & ";"
End If
Next
Next
If Len(newString) <> 0 Then
newString = Right$(newString, (Len(newString) - Len(seperator)))
End If
ConcatenateRange = newString
End Function
Run Code Online (Sandbox Code Playgroud)
如果我理解正确,你想要一个单元格,比如说J1包含所选单元格的所有值,用分号分隔?如果是这样,你可以修改你的第一个sub,
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Dim rng As Range
Set rng = Application.Selection
Dim vCell as Range
Range("J1").Value = ""
' Cycle through cells in range
For each vCell in rng
' Use if so that J1 doesn't start with a semi colon
If Range("J1").Value = "" Then
Range("J1").Value = vCell.Value
Else
Range("J1").Value = Range("J1").Value & ";" & vCell.Value
End If
Next vCell
End Sub
Run Code Online (Sandbox Code Playgroud)