##title##

2019年8月14日

Excel:VBA,使用變數選擇範圍(Range)

自己試著從零開始寫的第一個VBA
Sub ()
v1 = Cells(5, 1)    '對應的列、欄位置,變數訂為v1
v2 = Cells(6, 1)    '對應的列、欄位置,變數訂為v2
'MsgBox (v1)    '訊息彈窗可以用來檢查變數v1
Range(v1 & ":" & v2).Select '選擇目標欄位(已變數回傳值所指定的範圍)
Selection.Copy  '複製所選
End Sub




其中我原本A4位置的公式=COUNTA(1:1)-1,是用來計算A5和A6的=ADDRESS(3,5,4)及=ADDRESS(3,5+A4-1,4),所以可以改寫如下:


v1 = WorksheetFunction.CountA(Range("1:1")) - 1 '計算COUNTA(1:1)-1的值,將變數訂為v1
v2 = Cells(3, 5).Address    '計算ADDRESS(3,5,4)的值,將變數訂為v2
v3 = Cells(3, 5 + v1 - 1).Address    '計算ADDRESS(3,5 +v1 -1,4)的值,將變數訂為v3
Range(v2 & ":" & v3).Select '選擇目標欄位(已變數回傳值所指定的範圍)
Selection.Copy  '複製所選






參考資料:

EXCEL VBA從頭來過-基本語法(上篇)
https://medium.com/@weilihmen/excel-vba%E5%BE%9E%E9%A0%AD%E4%BE%86%E9%81%8E-%E5%9F%BA%E6%9C%AC%E8%AA%9E%E6%B3%95-%E4%B8%8A%E7%AF%87-c2bc76065ecd

提到cells、range


MsgBox 函式
https://docs.microsoft.com/zh-tw/office/vba/language/reference/user-interface-help/msgbox-function


如何在Excel VBA使用Excel工作表中的函數
http://wordpress.bestdaylong.com/blog/archives/2547


Thread: Using "Address" function in VBA?
https://www.mrexcel.com/forum/excel-questions/341078-using-address-function-vba.html

2019年8月7日

Excel:INDEX+MATCH=退著VLOOKUP

用vlookup的時候常常會遇到一個問題,只能傳回查的目標資料右方的資料。

如果用INDEX+MATCH就可以達到查目標資料左方的資料了。例如


=INDEX(C:C,MATCH(A2,D:D,0),1)

這樣的意思是在D欄查A2的資料,如果查到,回傳的值則當作INDEX函數中的列,並找出C欄對應列的值。


MATCH(lookup_value, lookup_array, [match_type])

MATCH 函數語法具有下列引數:

lookup_value    必要。 這是要在 lookup_array 中比對的值。 例如,當您在通訊錄中查閱某個人的號碼時,您是以那個人的姓名作為查閱值,但是電話號碼才是您要的值。

lookup_value 引數可以是一值 (數字、文字或邏輯值),也可以是數字、文字或邏輯值的儲存格參照。

lookup_array    必要。 這是要搜尋的儲存格範圍。

match_type    選擇性。 數字 -1、0 或 1。 match_type 引數會指定 Excel 如何將 lookup_value 與 lookup_array 中的值相比對。 這個引數的預設值是 1。

下表將描述該函數如何根據 match_type 引數的設定來尋找值。

MATCH函數參考:
https://support.office.com/zh-hk/article/match-%E5%87%BD%E6%95%B8-e8dffd45-c762-47d6-bf89-533f4a37673a


INDEX(array, row_num, [column_num])

陣列形式的 INDEX 函數具有下列引數:

array    必要。 儲存格範圍或陣列常數。

如果陣列包含只有一個資料列或欄,則相對應的 row_num 或 column_num 引數是選擇性的。

如果陣列有一個以上的列與多個欄中,使用 [僅限 row_num 或 column_num 設,INDEX 會傳回整列或欄的陣列陣列中。

row_num    必要。 選取列中的值傳回的陣列。 如果省略 row_num,column_num 是必要的。

column_num    選用。 選取要從中傳回值的陣列中的欄。 如果省略 column_num,row_num 是必要的。

註解
如果使用了 row_num 與 column_num 引數,INDEX 會傳回 row_num 與 column_num 交集處儲存格中的值。

row_num 及 column_num 必須對應到陣列; 內的儲存格否則,INDEX 會傳回 #REF ! 錯誤的非數字 (文字) 值,您的公式則會中斷。

如果將 row_num 或 column_num 設為 0 (零),INDEX 會分別傳回整欄或整列的值的陣列。 若要使用以陣列方式傳回的值,INDEX 函數輸入為陣列公式。

INDEX函數參考:
https://support.office.com/zh-hk/article/index-%E5%87%BD%E6%95%B8-a5dcf0dd-996d-40a4-a822-b56b061328bd