資料剖析(TextToColumns)對象可以不是儲存格嗎?
- 帖子
- 41
- 主題
- 11
- 精華
- 0
- 積分
- 83
- 點名
- 0
- 作業系統
- windows
- 軟體版本
- xp
- 閱讀權限
- 20
- 註冊時間
- 2012-12-20
- 最後登錄
- 2019-12-17
|
資料剖析(TextToColumns)對象可以不是儲存格嗎?
請教各位前輩
Selection.TextToColumns
其中Selection似乎一定要是range,那有辦法直接對陣列變數進行資料剖析嗎?
ex:dim A(3) as double
A(0)="1,2,3"
想不透過sheet把資料剖析成A(1)=2、A(2)=2、A(3)=3
有辦法這樣做嗎?
謝謝 |
|
|
|
|
|
|
- 帖子
- 41
- 主題
- 11
- 精華
- 0
- 積分
- 83
- 點名
- 0
- 作業系統
- windows
- 軟體版本
- xp
- 閱讀權限
- 20
- 註冊時間
- 2012-12-20
- 最後登錄
- 2019-12-17
|
3#
發表於 2013-2-4 13:40
| 只看該作者
回復 2# Hsieh
謝謝H大,應該說我會輸入一筆資料,此資料可能有兩種形態,第一種是純數字;ex:1 or 5 ...,第二種是字串;ex:1,3,5,
如果資料是字串的話我就用把它分割後丟進陣列裡,原本我會把它丟入某個儲存格中,在使用資料剖析(TextToColumns)做分割後再讀進陣列中,
之後計算就直接用陣列,不會使用到儲存格。
現在使用Split就可以不用資料剖析跟儲存格達到相同效果了!謝謝。 |
|
|
|
|
|
|
- 帖子
- 41
- 主題
- 11
- 精華
- 0
- 積分
- 83
- 點名
- 0
- 作業系統
- windows
- 軟體版本
- xp
- 閱讀權限
- 20
- 註冊時間
- 2012-12-20
- 最後登錄
- 2019-12-17
|
4#
發表於 2013-2-5 13:37
| 只看該作者
回復 2# Hsieh
而Split方法後的陣列元素,其資料型態則一律為String(字串)
如上圖,似乎使用Split後bb還是字串型態而不是陣列?
且使用val也不法將其改成數字型態,要換一個變數才能用val改成數字型態。
雖然說字串也能做數學運算就是了。 |
|
|
|
|
|
|
- 帖子
- 41
- 主題
- 11
- 精華
- 0
- 積分
- 83
- 點名
- 0
- 作業系統
- windows
- 軟體版本
- xp
- 閱讀權限
- 20
- 註冊時間
- 2012-12-20
- 最後登錄
- 2019-12-17
|
6#
發表於 2013-2-5 16:24
| 只看該作者
回復 5# Hsieh
謝謝,我理解了!
剛剛使用發現字串可以運算,但不能做<、=、>等判斷,只能要判斷時使用val或是像H大所說的存成另一個陣列來使用。 |
|
|
|
|
|
|
- 帖子
- 5923
- 主題
- 13
- 精華
- 1
- 積分
- 5986
- 點名
- 0
- 作業系統
- win10
- 軟體版本
- Office 2010
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台灣基隆
- 註冊時間
- 2010-5-1
- 最後登錄
- 2022-1-23
        
|
7#
發表於 2013-2-5 16:36
| 只看該作者
本帖最後由 GBKEE 於 2013-2-5 16:37 編輯
回復 6# chiata
使用發現字串可以運算,但不能做<、=、>等判斷- Option Explicit
- Sub Ex()
- Dim A As String, B As Variant
- A = "A5"
- B = "10"
- ' MsgBox A * B '** VBA 傳回: 錯誤值13 "型態不符合"
- If IsNumeric(A) And IsNumeric(B) Then MsgBox A * B Else MsgBox "型態不符合"
- A = "5"
- B = "10"
- If IsNumeric(A) And IsNumeric(B) Then MsgBox A * B Else MsgBox "型態不符合"
- A = "1,2,3,4,5,6,7,8,9,10"
- B = Split(A, ",")
- MsgBox B(0) * B(UBound(B))
- MsgBox B(0) < B(UBound(B)) '1 < 10 =True
- MsgBox B(0) > B(UBound(B)) '1 > 10 =False
- MsgBox B(0) = B(UBound(B)) '1 = 10 =False
- A = "1,2,3,4,5,6,7,8,9,A10"
- B = Split(A, ",")
- MsgBox B(0) * B(UBound(B)) '** VBA 傳回: 錯誤值13 "型態不符合"
- End Sub
複製代碼 |
|
|
|
|
|
|
- 帖子
- 41
- 主題
- 11
- 精華
- 0
- 積分
- 83
- 點名
- 0
- 作業系統
- windows
- 軟體版本
- xp
- 閱讀權限
- 20
- 註冊時間
- 2012-12-20
- 最後登錄
- 2019-12-17
|
8#
發表於 2013-2-8 14:10
| 只看該作者
回復 7# GBKEE - Sub test()
- For t = 1 To 110
- If t <= "10" Then MsgBox t
- Next t
-
- End Sub
- Sub test2()
- For t = 1 To 110
- If t <= Val("10") Then MsgBox t
- Next t
-
- End Sub
複製代碼 小弟遇到的問題...test只有t=1跟10會跳msgbox出來,test2就t=1~10都會跳,不知道是哪邊出問題...
謝謝 |
|
|
|
|
|
|
- 帖子
- 5923
- 主題
- 13
- 精華
- 1
- 積分
- 5986
- 點名
- 0
- 作業系統
- win10
- 軟體版本
- Office 2010
- 閱讀權限
- 150
- 性別
- 男
- 來自
- 台灣基隆
- 註冊時間
- 2010-5-1
- 最後登錄
- 2022-1-23
        
|
9#
發表於 2013-2-9 15:24
| 只看該作者
回復 8# chiata
你沒有宣告 變數t的型態為數字,vba將視為 字串的對字串的比對- Option Explicit '強制需宣告變數
- Sub test()
- Dim t As Integer
- For t = 1 To 110
- If t <= "15" Then MsgBox t
- Next t
- End Sub
- Sub test2()
- Dim t As Variant ' Variant 資料型態是所有沒被明確宣告為其他型態 **等同沒有宣告變數***
- For t = 1 To 110
- If t <= "10" Then MsgBox t & " <= 10"
- If t <= "20" Then MsgBox t & " <= 20"
- If t <= "30" Then MsgBox t & " <= 30"
- Next t
- End Sub
複製代碼 |
|
|
|
|
|
|
- 帖子
- 41
- 主題
- 11
- 精華
- 0
- 積分
- 83
- 點名
- 0
- 作業系統
- windows
- 軟體版本
- xp
- 閱讀權限
- 20
- 註冊時間
- 2012-12-20
- 最後登錄
- 2019-12-17
|
10#
發表於 2013-2-9 16:23
| 只看該作者
回復 9# GBKEE
謝謝G大,新年快樂,
圖中Variant/Integer不是代表此變數目前是Integer的狀態嗎?
我以為Variant是先埠指定變數型態,待程式執行後會自動判斷此變數合適型態,例如integer、string...等,使用上比較有彈性。
還是我觀念錯誤?? |
|
|
|
|
|
|