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
| Sub Test()
Dim R As Range
Set R = Sheets("Data").UsedRange
Dim DerL As Long
Dim DerC As Integer
Dim Mail As String
DerC = 1
For l = 1 To R.Rows.Count Step 4
DerL = SerchXls(Sheets("Resultats").Range("D:D"), Sheets("Resultats").Range("D1"), Trim("" & R(l, 1).Offset(3)), True)
If DerL <> 0 Then
DerC = Sheets("Resultats").Cells(DerL, Columns.Count).End(xlToLeft).Column + 1
Else
DerL = Sheets("Resultats").Cells(Cells.Rows.Count, 1).End(xlUp).Row + 1
End If
If InStr(Trim("" & R(l, 1).Offset(4)), ",") = 0 And Trim("" & R(l, 1).Offset(4)) <> "" Then
If DerL = 1 Then DerL = 2
Mail = Trim("" & R(l, 1).Offset(3))
Sheets("Resultats").Range(Sheets("Resultats").Cells(DerL, 1), Sheets("Resultats").Cells(DerL, 1).Offset(0, 4)) = Application.Transpose(R.Range(R.Cells(l, 1), R(l, 1).Offset(4)))
l = l + 1
Else
If DerL = 1 Then DerL = 2
Mail = Trim("" & R(l, 1).Offset(3))
Sheets("Resultats").Range(Sheets("Resultats").Cells(DerL, DerC), Sheets("Resultats").Cells(DerL, DerC).Offset(0, 3)) = Application.Transpose(R.Range(R.Cells(l, 1), R(l, 1).Offset(3)))
End If
Next
End Sub
Function SerchXls(Myrange As Range, MyCellule As Range, strRecherche, EntierCell As Boolean) As Long '
On Error Resume Next
Dim CellEntrier As Integer
If EntierCell = True Then CellEntrier = xlWhole Else CellEntrier = xlPart
SerchXls = 0
SerchXls = Myrange.Cells.Find(what:=strRecherche, After:=MyCellule, LookIn:=xlFormulas, LookAt _
:=CellEntrier, SearchOrder:=xlByRows, SearchDirection:=xlNext, MatchCase:= _
False, SearchFormat:=EntierCell).Row
If SerchXls <= MyCellule.Row Then SerchXls = 0
End Function |
Partager