- 帖子
- 4901
- 主題
- 44
- 精華
- 24
- 積分
- 4916
- 點名
- 142
- 作業系統
- Windows 7
- 軟體版本
- Office 20xx
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台北
- 註冊時間
- 2010-4-30
- 最後登錄
- 2025-6-12
               
|
回復 5# candy516
日期順序看錯,要往上15天才對
順便將無資料條件改一下- Sub ex()
- Dim A As Range, B As Range, B1 As Range, B2 As Range, C As Range, Rng As Range, Rng1 As Range, d As Object
- Set d = CreateObject("Scripting.Dictionary")
- Set sht = Sheets.Add(after:=Sheets(1))
- Application.ScreenUpdating = False
- With Sheet1
- For Each A In .Range(.[A2], .[A65536].End(xlUp))
- mystr = A & "," & Left(A.Offset(, 1), 4)
- d(mystr) = DateValue(Format(A.Offset(, 1), "0000/00/00"))
- Next
- End With
- k = 1: r = 1
- For Each ky In d.keys
- y = Split(ky, ",")(1)
- With Sheets(y)
- Set C = .Columns("A").Find(d(ky))
- Set B = .Rows(1).Find(Split(ky, ",")(0))
- If Not C Is Nothing And Not B Is Nothing Then
- x = Application.Max(3, C.Row - 14)
- Set B1 = .[A1:A2]
- Set B2 = B.Resize(2, 1)
- Set Rng = .Cells(x, 1).Resize(15, 1)
- Set Rng1 = .Cells(x, B.Column).Resize(15, 1)
- With sht
- B1.Copy .Cells(r, k)
- B2.Copy .Cells(r, k + 1)
- Rng.Copy .Cells(r + 2, k)
- Rng1.Copy .Cells(r + 2, k + 1)
- End With
- k = IIf(k = 255, 1, k + 2)
- r = IIf(k = 1, r + 18, r)
- Else
- MsgBox "無此除權資料"
- End If
- End With
- Next
- Application.ScreenUpdating = True
- End Sub
複製代碼 |
|