1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
| Dim m As Integer
Function ConcatenationLR(ligne As Integer, counter As Integer) As String
Dim lignef As Integer
Dim expression As String
Dim counterf As Integer
lignef = ligne
counterf = counter
expression = Range("F" & lignef).Value
'Test si champs vide
If expression <> "" Then
' concaténer valeurs des cellules si non vides
For m = lignef + 1 To lignef + counterf
If Range("F" & m) <> "" Then
expression = expression & ", " & Range("F" & m)
End If
Next
Else: expression = ConcatenationLR(lignef + 1, counterf - 1)
End If
'test de la valeur d'expression -> prend bien la bonne valeur même quand F1 est vide!
MsgBox expression, vbDefaultButton2
ConcatenationLR = expression
End Function
Sub ok()
Sheets("Feuil1").Select
'Range("A3").Value ne prend pas la bonne valeur quand F1 est vide.....!
Range("A3").Value = ConcatenationLR(1, 8)
End Sub |