返回列表 上一主題 發帖

資料剖析(TextToColumns)對象可以不是儲存格嗎?

資料剖析(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
有辦法這樣做嗎?

謝謝

例如t = 6
if 的時候
if (t<="10") then....
會變成
if ("6"<="10") then....
而不是
if (6<=10) then....
kimbal 發表於 2013-2-16 17:07


謝謝各位前輩,我暸解了!
但似乎一步一步執行程式,在If t <= 10跟If t <= "10"中t的型態都還是variant/Integer,可是實際上在If t <= "10"時VBA是用variant/String去判斷?
  1. Sub test()
  2.     Dim t As Variant
  3.     For t = 1 To 10
  4.         If t <= 10 Then MsgBox t & " <= 10"
  5.         If t <= "10" Then MsgBox t & " <= 10"
  6.     Next t
  7. End Sub
複製代碼

TOP

回復  GBKEE
謝謝G大,新年快樂,
圖中Variant/Integer不是代表此變數目前是Integer的狀態嗎 ...
chiata 發表於 2013-2-9 16:23



t 是 variant/Integer 是對的.
但是當 在if 的時候
因為右方 "10" 是 文字, 不是數字,  if會把t轉為文字再對比 (VBA來看, " "裡的是文字)

例如t = 6
if 的時候
if (t<="10") then....
會變成
if ("6"<="10") then....
而不是
if (6<=10) then....

而文字"6" 第1個字 即 "6"  比 "10"的第1個字 "1" 大
換句話說 "6"<="10" 就是等於FALSE

TEST要這樣寫才可以得出效果
  1. Option Explicit         '強制需宣告變數
  2. Sub test()
  3.    Dim t As Integer
  4.    For t = 1 To 110
  5.        If t <= 15 Then MsgBox t
  6.    Next t
  7. End Sub

  8. Sub test2()
  9.     Dim t As Variant  
  10.     For t = 1 To 110
  11.        If t <= 15 Then MsgBox t & " <= 10"
  12.    Next t
  13. End Sub
複製代碼
不指明類型,是會比較方便些, 但是會增加像這樣的錯誤機會.
微軟近年來對Variant的方針也是變來變去.
懂得發問,答案就會在其中

今日の一秒は  明日にない
http://kimbalko-chi.blogspot.com
http://kimbalko.blogspot.com

TOP

回復 10# chiata
  1. Sub test1()
  2.     Dim t As Integer
  3.     For t = 1 To 110
  4.         If t <= "9" Then MsgBox t & " <= 9"
  5.         If t <= "10" Then MsgBox t & " <= 10"
  6.     Next t
  7. End Sub
  8. Sub test2()
  9.     't 沒有明確宣告   
  10. For t = 1 To 110
  11.         If t > "30" Then MsgBox t & " > 30"         '當t<=9 為1位數 比對字串的第一位 "3"
  12.         If t <= "9" Then MsgBox t & " <= 9"        '當t<=9 為1位數 比對字串的第一位 "9"
  13.         If t <= "10" Then MsgBox t & " <= 10"   '當t<=9 為1位數 比對字串的第一位 "1"
  14.         MsgBox TypeName(t)
  15.     Next t
  16. End Sub
複製代碼

TOP

回復 9# GBKEE


   

謝謝G大,新年快樂,
圖中Variant/Integer不是代表此變數目前是Integer的狀態嗎?
我以為Variant是先埠指定變數型態,待程式執行後會自動判斷此變數合適型態,例如integer、string...等,使用上比較有彈性。
還是我觀念錯誤??

TOP

回復 8# chiata
你沒有宣告 變數t的型態為數字,vba將視為 字串的對字串的比對
  1. Option Explicit         '強制需宣告變數
  2. Sub test()
  3.     Dim t As Integer
  4.     For t = 1 To 110
  5.         If t <= "15" Then MsgBox t
  6.     Next t   
  7. End Sub
  8. Sub test2()
  9.     Dim t As Variant  ' Variant 資料型態是所有沒被明確宣告為其他型態  **等同沒有宣告變數***
  10.     For t = 1 To 110
  11.         If t <= "10" Then MsgBox t & " <= 10"
  12.         If t <= "20" Then MsgBox t & " <= 20"
  13.         If t <= "30" Then MsgBox t & " <= 30"
  14.     Next t
  15. End Sub
複製代碼

TOP

回復 7# GBKEE
  1. Sub test()

  2.     For t = 1 To 110
  3.         If t <= "10" Then MsgBox t
  4.     Next t
  5.    
  6. End Sub
  7. Sub test2()

  8.     For t = 1 To 110
  9.         If t <= Val("10") Then MsgBox t
  10.     Next t
  11.    
  12. End Sub
複製代碼
小弟遇到的問題...test只有t=1跟10會跳msgbox出來,test2就t=1~10都會跳,不知道是哪邊出問題...
謝謝

TOP

本帖最後由 GBKEE 於 2013-2-5 16:37 編輯

回復 6# chiata
使用發現字串可以運算,但不能做<、=、>等判斷
  1. Option Explicit
  2. Sub Ex()
  3.     Dim A As String, B As Variant
  4.     A = "A5"
  5.     B = "10"
  6. '    MsgBox A * B   '** VBA 傳回: 錯誤值13  "型態不符合"
  7.     If IsNumeric(A) And IsNumeric(B) Then MsgBox A * B Else MsgBox "型態不符合"
  8.     A = "5"
  9.     B = "10"
  10.     If IsNumeric(A) And IsNumeric(B) Then MsgBox A * B Else MsgBox "型態不符合"
  11.     A = "1,2,3,4,5,6,7,8,9,10"
  12.     B = Split(A, ",")
  13.     MsgBox B(0) * B(UBound(B))
  14.     MsgBox B(0) < B(UBound(B))  '1 < 10 =True
  15.     MsgBox B(0) > B(UBound(B))  '1 > 10 =False
  16.     MsgBox B(0) = B(UBound(B))  '1 = 10 =False  
  17.     A = "1,2,3,4,5,6,7,8,9,A10"
  18.     B = Split(A, ",")
  19.     MsgBox B(0) * B(UBound(B))    '** VBA 傳回: 錯誤值13  "型態不符合"
  20. End Sub
複製代碼

TOP

回復 5# Hsieh

謝謝,我理解了!
剛剛使用發現字串可以運算,但不能做<、=、>等判斷,只能要判斷時使用val或是像H大所說的存成另一個陣列來使用。

TOP

回復 4# chiata

在2#回覆中已經說明SPLIT所得到的是字串型態的陣列
而陣列無法改變其資料型態,唯有以另一資料型態陣列儲存才可改變元素的資料型態
  1. Sub ex()
  2. Dim ar()
  3. a = "1,3,5,7,9"
  4. bb = Split(a, ",")
  5. ReDim ar(UBound(bb))
  6. For i = 0 To UBound(bb)
  7. ar(i) = CDbl(bb(i))
  8. MsgBox ar(i) & "  IS  " & TypeName(ar(i))
  9. Next
  10. End Sub
複製代碼
學海無涯_不恥下問

TOP

        靜思自在 : 人的心地是一畦田,土地沒有播下好種子,也長不出好的果實。 -
返回列表 上一主題