- 帖子
- 5923
- 主題
- 13
- 精華
- 1
- 積分
- 5986
- 點名
- 0
- 作業系統
- win10
- 軟體版本
- Office 2010
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台灣基隆
- 註冊時間
- 2010-5-1
- 最後登錄
- 2022-1-23
        
|
3#
發表於 2011-5-18 08:45
| 只看該作者
回復 2# aseeddie
你的程式碼是最簡短的,但資料量大時會較費時的- Sub Ex1()
- Dim Rng As Range
- Set Rng = Range("A1")
- Do
- If Application.CountA(Range(Rng, Rng.End(xlDown).Offset(-1))) = 1 Then
- If Rng.End(xlDown).Row = Rows.Count Then
- Range(Rng, Cells(200, "a")) = Rng
- Exit Do
- End If
- Range(Rng, Rng.End(xlDown).Offset(-1)) = Rng
- End If
- Set Rng = Rng.End(xlDown)
- Loop
- End Sub
複製代碼- Sub Ex2()
- Dim Rng As Range, Ar(), i%
- Set Rng = Range("A1")
- Ar = Rng
- For i = 2 To UBound(Ar)
- If Ar(i, 1) = "" Then Ar(i, 1) = Ar(i - 1, 1)
- Next
- Rng = Ar
- End Sub
複製代碼 |
|