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 35 36 37 38 39 40
|
Option Explicit
Sub Test()
Dim I As Integer, DerniereColonne As Integer, DerniereLigne As Integer
With Sheets("datas")
DerniereColonne = .Cells(1, .Columns.Count).End(xlToLeft).Column
DerniereLigne = .Cells(.Rows.Count, 1).End(xlUp).Row
.Cells(1, DerniereColonne + 1).Formula = "=SUBTOTAL(9," & .Range(.Cells(2, DerniereColonne + 1), .Cells(DerniereLigne, DerniereColonne + 1)).Address & ")"
.Cells(1, DerniereColonne + 1).NumberFormat = "#,##0.00 $"
For I = 2 To DerniereLigne
.Cells(I, DerniereColonne + 1) = Conversion(.Cells(I, DerniereColonne))
.Cells(I, DerniereColonne + 1).NumberFormat = "#,##0.00 $"
Next I
End With
End Sub
Function Conversion(ByVal Valeur As String) As Variant
Dim I As Integer
Conversion = ""
For I = 1 To Len(Valeur)
Select Case Mid(Valeur, I, 1)
Case Chr(32), Chr(160), ""
Case 0 To 9, ","
Conversion = Conversion & Mid(Valeur, I, 1)
End Select
Next I
Conversion = CDbl(Conversion)
End Function |
Partager