- 帖子
- 4901
- 主題
- 44
- 精華
- 24
- 積分
- 4916
- 點名
- 121
- 作業系統
- Windows 7
- 軟體版本
- Office 20xx
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台北
- 註冊時間
- 2010-4-30
- 最後登錄
- 2025-5-19
               
|
回復 27# emma
是不是這樣效果?- Private Sub Worksheet_Change(ByVal Target As Range)
- Dim Ar(), A As Range
- If Target.Address <> "$B$1" Then Exit Sub
- If Application.CountA(Range([A5], Cells(Rows.Count, 1))) > 0 Then
- For Each A In Range([A5], Cells(Rows.Count, 1).End(xlUp))
- ReDim Preserve Ar(s)
- Ar(s) = Application.Transpose(Application.Transpose(A.Resize(, 8)))
- s = s + 1
- Next
- End If
-
- With Sheet1
- If Application.Count(.Range("B:B")) > 0 Then
- For Each A In .Range("B:B").SpecialCells(xlCellTypeConstants, 1)
- ReDim Preserve Ar(s)
- If A.Offset(, 8) = "V" And (A.Offset(, 9) > Date Or A.Offset(, 9) = "") And A > A.Offset(, 4) Then dot = Int(A / 1000) * 1000 Else dot = 0
- k = IIf(Target = "總店", 10, 11)
- If A < A.Offset(, 4) Then
- m = "運費+手續費"
- ElseIf A.Offset(, 5) = "推" And A > A.Offset(, 4) Then
- m = "免運"
- ElseIf A.Offset(, 5) <> "推" And A > A.Offset(, 4) Then
- m = "運費"
- End If
- Ar(s) = Array(A.Offset(, 2).Value, A.Value, A.Offset(, 3).Value, dot, A.Offset(, 12).Value, A.Offset(, k).Value, m, A.Offset(, 6).Value)
- s = s + 1
- Next
- End If
- End With
- If s > 0 Then [A5].Resize(s, 8) = Application.Transpose(Application.Transpose(Ar))
- Range("A4").CurrentRegion.Sort key1:=[A4], Header:=xlYes
- End Sub
複製代碼
VBAtest7.rar (19.28 KB)
|
|