新手問題,如何篩選後自動將資料由第一欄刪除至最後一欄???
- 帖子
- 134
- 主題
- 27
- 精華
- 0
- 積分
- 168
- 點名
- 0
- 作業系統
- WINXP
- 軟體版本
- EXCEL 2003
- 閱讀權限
- 20
- 性別
- 男
- 來自
- 雲林
- 註冊時間
- 2010-10-6
- 最後登錄
- 2018-5-13

|
新手問題,如何篩選後自動將資料由第一欄刪除至最後一欄???
本帖最後由 p6703 於 2012-1-5 11:33 編輯
小弟近期開始學習VBA,現階段還是使用錄製的方式學習,因資料每次均會有所變更,原錄製時是按定當時該列數(例,上次錄製的列數為11列開始刪除,但下次的資料篩選後的資料由第2列開始時,2~10列的資料就無法刪除了),請問如何設定巨集,使其篩選後由第一符合條件的資料開始刪除至最後一列
另如何設定指定欄位的資料只要符合某條件,即自動將除了該條件外的資料全數刪除???(例:E欄凡有M開頭的資料留著,其餘原資料自動刪除)==>如要多欄位符合設定條件,是否也可依樣作業即可達成???
如於備註欄位填入多列資料,可否依每列固定行高15,自動調整適當的列高(例:如欄位內有4列,即列高為60)
以上問題煩請先進不吝指教,先在此謝謝了:handshake
感謝GBKEE兄即時的告知,已將資料附件如下
Book2.rar (2.29 KB)
|
|
|
|
|
|
|
- 帖子
- 134
- 主題
- 27
- 精華
- 0
- 積分
- 168
- 點名
- 0
- 作業系統
- WINXP
- 軟體版本
- EXCEL 2003
- 閱讀權限
- 20
- 性別
- 男
- 來自
- 雲林
- 註冊時間
- 2010-10-6
- 最後登錄
- 2018-5-13

|
3#
發表於 2012-1-9 09:30
| 只看該作者
這幾天摸索因VBA仍不熟,只用其他方法也先有解決了小弟的問題,說明如下:
1.指定最上層列數由下刪除,指定為第2行一樣可達成,因篩選後只會秀出符合條件的值,由第2列刪除再取消篩選,並不會將原2列未符合條件的資料一併刪除
2.小弟是以庫位篩選,將預計要留除的庫位資料秀於其他工作表,然後以VLOOKUP比對只要非該庫位的就於資料最後一欄位自動秀出"*",並用篩選將*列數刪除,再用重新排序即可完成留下指定庫位的資料
現只有第3點問題仍無法解決,請各位先進協助是否可依指定欄位的列數自動設定其列高???(一列固定列高15) |
|
|
|
|
|
|
- 帖子
- 5923
- 主題
- 13
- 精華
- 1
- 積分
- 5986
- 點名
- 0
- 作業系統
- win10
- 軟體版本
- Office 2010
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台灣基隆
- 註冊時間
- 2010-5-1
- 最後登錄
- 2022-1-23
        
|
4#
發表於 2012-1-9 11:19
| 只看該作者
回復 3# p6703
一列固定列高15 錄製後可套入- Option Explicit
- Sub Ex() '此程式:請篩選資料後套上
- Dim Rng As Range, Rng1 As Range, E As Range
- With ActiveSheet '作用中工作表
- If .FilterMode = True Then '如果指定活頁簿處於有篩選模式則為 True
- Set Rng = .UsedRange.SpecialCells(xlCellTypeVisible) '設定篩選資料範圍
- '****方式1 顯示所有資料
- .AutoFilterMode = False '屬性為 False 取消工作表 [自動篩選]
- '如果目前在工作表上顯示有 [自動篩選] 下拉箭號,則此屬性為 True
- '****方式2 顯示所有資料
- ' .ShowAllData 'ShowAllData 方法: 使目前篩選清單的所有列均可見。如果正在使用自動篩選,本方法將箭頭變更為 [全部]。
- '如處於沒有篩選模式: ShowAllData會有錯誤
- For Each E In .UsedRange.Rows '所有資料列
- If Application.Intersect(E, Rng) Is Nothing Then '比對資料列: 不在篩選資料範圍內
- If Rng1 Is Nothing Then '未設定Rng1
- Set Rng1 = E '第一次:設定Rng1
- Else
- Set Rng1 = Union(E, Rng1) '第一次以後:設定範圍加上(Union)上次 Rng1
- End If
- End If
- Next
- Rng1.Delete xlShiftUp '刪除不是篩選資料範圍內的Range 下方上移
- End If
- End With
- End Sub
複製代碼 |
|
|
|
|
|
|
- 帖子
- 134
- 主題
- 27
- 精華
- 0
- 積分
- 168
- 點名
- 0
- 作業系統
- WINXP
- 軟體版本
- EXCEL 2003
- 閱讀權限
- 20
- 性別
- 男
- 來自
- 雲林
- 註冊時間
- 2010-10-6
- 最後登錄
- 2018-5-13

|
5#
發表於 2012-1-9 16:48
| 只看該作者
感謝GBKEE兄,但我希望的列高,是會依附件中的F欄位列數去自動調整,例如:第2列有3行,則其行高會自動變為45, 第11列有5行,則其行高為75,依此類推...
另篩選的巨集會再仔細研究一下,先行感謝...^^ |
|
|
|
|
|
|
- 帖子
- 5923
- 主題
- 13
- 精華
- 1
- 積分
- 5986
- 點名
- 0
- 作業系統
- win10
- 軟體版本
- Office 2010
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台灣基隆
- 註冊時間
- 2010-5-1
- 最後登錄
- 2022-1-23
        
|
6#
發表於 2012-1-10 09:19
| 只看該作者
本帖最後由 GBKEE 於 2012-1-10 11:12 編輯
回復 5# p6703
看看你是需要哪個 列高調整- Sub 列高調整()
- ActiveSheet.Cells.EntireRow.AutoFit
- End Sub
複製代碼- Option Explicit
- Sub 列高調整()
- Dim Rng As Range, Ar(), I
- With ActiveSheet
- .Cells.EntireRow.AutoFit
- Set Rng = .Range("A2:A" & [A2].End(xlDown).Row)
- Ar = Rng
- For I = 1 To Rng.Count
- Ar(I, 1) = Rng(I).RowHeight
- Next
- Rng.RowHeight = Application.Max(Ar)
- End With
- End Sub
複製代碼- Option Explicit
- Sub Ex() '此程式:請篩選資料後套上
- Dim Rng As Range, Rng1 As Range, E As Range
- With ActiveSheet '作用中工作表
- If .FilterMode = True Then '如果指定活頁簿處於有篩選模式則為 True
- Set Rng = .UsedRange.SpecialCells(xlCellTypeVisible) '設定篩選資料範圍
- '****方式1 顯示所有資料
- .AutoFilterMode = False '屬性為 False 取消工作表 [自動篩選]
- '如果目前在工作表上顯示有 [自動篩選] 下拉箭號,則此屬性為 True
- '****方式2 顯示所有資料
- ' .ShowAllData 'ShowAllData 方法: 使目前篩選清單的所有列均可見。如果正在使用自動篩選,本方法將箭頭變更為 [全部]。
- '如處於沒有篩選模式: ShowAllData會有錯誤
- For Each E In .UsedRange.Rows '所有資料列
- If Application.Intersect(E, Rng) Is Nothing Then '比對資料列: 不在篩選資料範圍內
- If Rng1 Is Nothing Then '未設定Rng1
- Set Rng1 = E '第一次:設定Rng1
- Else
- Set Rng1 = Union(E, Rng1) '第一次以後:設定範圍加上(Union)上次 Rng1
- End If
- End If
- Next
- Rng1.Delete xlShiftUp '刪除不是篩選資料範圍內的Range 下方上移
- End If
- End With
- 列高調整 '
- End Sub
複製代碼 |
|
|
|
|
|
|
- 帖子
- 134
- 主題
- 27
- 精華
- 0
- 積分
- 168
- 點名
- 0
- 作業系統
- WINXP
- 軟體版本
- EXCEL 2003
- 閱讀權限
- 20
- 性別
- 男
- 來自
- 雲林
- 註冊時間
- 2010-10-6
- 最後登錄
- 2018-5-13

|
7#
發表於 2012-1-11 18:46
| 只看該作者
感謝GBKEE兄,小弟仍不明巨集用法,特再請問:
第二種巨集執行後行高變為36,且好像每個報表執行起來行高均不同,且於巨集中未見有指定以F欄位行高判定,不知是否可再加以解釋巨集的用法??? |
|
|
|
|
|
|
- 帖子
- 5923
- 主題
- 13
- 精華
- 1
- 積分
- 5986
- 點名
- 0
- 作業系統
- win10
- 軟體版本
- Office 2010
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台灣基隆
- 註冊時間
- 2010-5-1
- 最後登錄
- 2022-1-23
        
|
8#
發表於 2012-1-11 20:18
| 只看該作者
回復 7# p6703
且好像每個報表執行起來行高均不同 當然是不一樣 你沒說有要執行一個以上的報表啊- Option Explicit 'Option Explicit 陳述式 在模組層次中強迫每個在模組裏的變數都必須明確的宣告。
- Sub 列高調整()
- Dim Rng As Range, Ar(), i As Integer
- With ActiveSheet '作用中的工作表
- .Cells.EntireRow.AutoFit 'ActiveSheet.Cells : ActiveSheet的儲存格
- Set Rng = .Range("A2:A" & [A2].End(xlDown).Row)
- 'a2 到 a2.End(xlDown)(往下到最後的資料).Row(列號)
- '可改為F欄 .Range("F2:F" & [F2].End(xlDown).Row)
- Ar = Rng 'Ar陣列元素=Rng的(內容)數量: Ar陣列元素=Range 是為二維陣列
- For i = 1 To Rng.Count
- Ar(i, 1) = Rng(i).RowHeight
- ' Ar(i, 1) : Ar(i, 第2維素) Ar陣列第2維素=1
- 'Rng(i).RowHeight : Rng的(i)的儲存格之RowHeight(列高)
- Next
- Rng.RowHeight = Application.Max(Ar) '取得Ar陣列元素中的最大值
- End With
- End Sub
複製代碼 |
|
|
|
|
|
|
- 帖子
- 134
- 主題
- 27
- 精華
- 0
- 積分
- 168
- 點名
- 0
- 作業系統
- WINXP
- 軟體版本
- EXCEL 2003
- 閱讀權限
- 20
- 性別
- 男
- 來自
- 雲林
- 註冊時間
- 2010-10-6
- 最後登錄
- 2018-5-13

|
9#
發表於 2012-1-11 21:39
| 只看該作者
呵呵..感謝GBKEE兄啦,我只是想說往後可能還可運用,按以上巨集執行後應可符合要求了,但小弟還是有一問題,雖然已可按欄位要求自動設定列高,但發現是按預設的列高12去調整的,因小弟使用的習慣字體大小為9時,適當的列高為15,這是否可再經由巨集調整呢??? |
|
|
|
|
|
|
- 帖子
- 5923
- 主題
- 13
- 精華
- 1
- 積分
- 5986
- 點名
- 0
- 作業系統
- win10
- 軟體版本
- Office 2010
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台灣基隆
- 註冊時間
- 2010-5-1
- 最後登錄
- 2022-1-23
        
|
10#
發表於 2012-1-12 16:18
| 只看該作者
回復 9# p6703
請自行套入- Sub Ex()
- With Sheet1.Range("A1:A10").EntireRow
- .RowHeight = 15
- .Font.Size = 9
- End With
- End Sub
複製代碼 |
|
|
|
|
|
|