返回列表 上一主題 發帖

[發問] 擷取報表中所需資料

回復 10# asus103
程式提取的學號已經是數字了
  1. Sub Ex()
  2. Dim A As Range, Ar(), C, d As Object, d1 As Object, d2 As Object, r&, MyClass$, Ky, s%, i%
  3. Set d = CreateObject("Scripting.Dictionary")
  4. Set d1 = CreateObject("Scripting.Dictionary")
  5. Set d2 = CreateObject("Scripting.Dictionary")
  6. With Sheets("Sheet1")
  7.   For Each A In .Range(.[B1], .Cells(.Cells.Rows.Count, 2).End(xlUp))
  8.      If A Like "*班" Then MyClass = A.Value
  9.      If Replace(A.Value, " ", "") = "學號" Then Ar = .Range(A, A.End(xlToRight)).Value
  10.      If Val(A.Value) <> 0 And InStr(A, "-") = 0 Then
  11.        s = 0
  12.        For Each C In Ar
  13.         If C <> "" Then d1(C) = ""
  14.          If C = "姓名" Then d1("班級") = "": d(A & "班級") = MyClass
  15.          d2(A.Value) = ""
  16.          d(A & C) = A.Offset(, s).Value
  17.          s = s + 1
  18.        Next
  19.     End If
  20.   Next
  21. End With
  22. With Sheets("Sheet4")
  23. .Cells = ""
  24. r = 2
  25. .[A1].Resize(, d1.Count) = d1.KEYS
  26. For Each Ky In d2.KEYS
  27.    For i = 1 To d1.Count
  28.       .Cells(r, i) = IIf(d(Ky & .Cells(1, i)) = "", -1, d(Ky & .Cells(1, i)))
  29.    Next
  30. r = r + 1
  31. Next
  32. End With
  33. End Sub
複製代碼
學海無涯_不恥下問

TOP

本帖最後由 asus103 於 2010-12-30 14:27 編輯

回復 11# Hsieh
對不起
是我沒有說清楚
是班級名稱,如三年二班改為302....

還有另外一個小問題
原始資料中若是"姓  名"不是"姓名"(如B7中是"姓  名"時,(中間有空白))
浪費您許多寶貴的時間,
只能在一次跟您說感謝
謝謝您
ASUS

TOP

回復 12# asus103
  1. Sub Ex()
  2. Dim A As Range, Ar(), C, d As Object, d1 As Object, d2 As Object, r&, MyClass$, Ky, s%, i%
  3. Set d = CreateObject("Scripting.Dictionary")
  4. Set d1 = CreateObject("Scripting.Dictionary")
  5. Set d2 = CreateObject("Scripting.Dictionary")
  6. With Sheets("Sheet1")
  7.   For Each A In .Range(.[B1], .Cells(.Cells.Rows.Count, 2).End(xlUp))
  8.      If A Like "*班" Then MyClass = A.Value
  9.      If Replace(A.Value, " ", "") = "學號" Then Ar = .Range(A, A.End(xlToRight)).Value
  10.      If Val(A.Value) <> 0 And InStr(A, "-") = 0 Then
  11.        s = 0
  12.        For Each C In Ar
  13.         If C <> "" Then d1(C) = ""
  14.          If C = "姓名" Then d1("班級") = "": d(A & "班級") = Replace(Replace(Replace(Replace(Replace(Replace(MyClass, "高", ""), "年", ""), "班", ""), "三", 3), "二", 2), "一", 1)
  15.          d2(A.Value) = ""
  16.          d(A & C) = IIf(s > 5, "", "'") & A.Offset(, s).Text
  17.          s = s + 1
  18.        Next
  19.     End If
  20.   Next
  21. End With
  22. With Sheets("Sheet4")
  23. .Cells = ""
  24. r = 2
  25. .[A1].Resize(, d1.Count) = d1.KEYS
  26. For Each Ky In d2.KEYS
  27.    For i = 1 To d1.Count
  28.       .Cells(r, i) = IIf(d(Ky & .Cells(1, i)) = "", -1, d(Ky & .Cells(1, i)))
  29.    Next
  30. r = r + 1
  31. Next
  32. End With
  33. End Sub
複製代碼
學海無涯_不恥下問

TOP

回復 13# Hsieh

全目標達成!!!!
非常地感謝您

附註:
有一個好玩的現象我會去研究
輸出的成績中,前三個是文字格式,之後是數字格式

再次感激
從這之間,我也學到好多,更明白"不足的更多"
ASUS

TOP

改這行
d(A & C) = IIf(s > 2, "", "'") & A.Offset(, s).Text
學海無涯_不恥下問

TOP

回復 15# Hsieh
完全完美狀態!!!!!!您真是神人啊!!!!
我會以此為目標努力的!!
再一次感謝!!!
ASUS

TOP

回復 13# Hsieh

Hsieh大大您好:
感謝您的熱心協助,工作上的問題已經OK
但基於想要把VBA學好的心情,關於這個程式的巧妙之處,是否可以繼續請教您
這幾天我先看了一本VBA入門的書
也詳細看了您發表的一些文章,如"Dictionary物件的認識與應用"、"VBA的寫作技巧與增進效能"、"學習 Excel VBA的一些基本概念"等,獲益良多
但此程式中的一些程式碼我還是看不懂
如:
    For Each C In Ar
        If C <> "" Then d1(C) = ""
         If C = "姓 名" Then d1("班級") = "": d(A & "班級") = Replace(Replace(Replace(Replace(Replace(Replace(MyClass, "高", ""), "年", ""), "班", ""), "三", 3), "二", 2), "一", 1)
         d2(A.Value) = ""
         d(A & C) = IIf(s > 20, "", "'") & A.Offset(, s).Text
         '改變 s 可改變成績以文字或數字格式
         s = s + 1
       Next
這段中是如何將資料指定進入d、d1、d2這三個Dictionary物件的呢?
執行完d1(C) = ""後,d1的變數內容中竟然就出現count=1、Item1="學號"?真是太神奇了
"d1("班級") = "": d(A & "班級") ="的語法是甚麼?我想他是為了把班級這個ITEM指定進d1的第三項,但他是怎麼辦到的呢?

不好意思,小弟愚昧尚有許多不明之處,
期待您的相助之後,繼續探索VBA的世界
ASUS

TOP

回復 17# asus103

http://forum.twbts.com/thread-20-1-1.html
先對該物件的屬性理解後再繼續討論
學海無涯_不恥下問

TOP

本帖最後由 asus103 於 2011-1-3 14:14 編輯

回復 18# Hsieh
您好:
這篇內容,我有印下來,讀了好幾次,可能是我沒有掌握到重點
把資料加入 Dictionary物件的語法:dictionary_object.Add index, content
可是您在程式中用的是『d1(C) = ""』OR『d2(A.Value) = ""』結果在"區域變數"中竟然就出現count=1、Item1="學號".....
我無法推知其content是如何取得(index我猜可能是順序遞加是嗎?)
如果我猜想d1(C) = ""這個程式碼的意義是
若C不在d1中,那麼就依序加入d1(index、count都加1)這樣對嗎?
那其語法為何?
另外
If C = "姓名" Then d1("班級") = "": d(A & "班級") = MyClass
中: 的意義是指在then的範圍之中,並且可以省略ENDIF是嗎?而不只是單純的分行符號
問題很蠢,但
尚請賜教
ASUS

TOP

回復 19# asus103


    dictionary物件觀念可用容器來做比喻
這個容器他是隨著資料多寡而跟著產生儲位的
這個儲位可以由使用者自行編號來表示
這個編號就是引數中的(index)key,關鍵字
至於這個儲位要放置的東西就是(content)item,內容
參考VBA說明
Dictionary 物件
               
描述

物件,用於儲存資料關鍵字和項目對。

語法

Scripting.Dictionary

請注意

Dictionary 可以是任何型式的資料的項目被儲存在陣列中。每個項目都與一個唯一的關鍵字相關。該關鍵字用來取出單個項目,通常是整數或字串,可以是除陣列外的任何型態。
由以上說明可知,
Dictionary 就是一個容器物件。
再看他有哪些方法?
add   加入項目
exists   檢查項目是否存在
items    傳回所有項目陣列
keys     傳回所有項目之關鍵字陣列
remove   移除項目
removeall   移除所有項目

VBA說明中對ADD方法有提到
Add 方法 (目錄)   

描述

加入一對相對應的關鍵字和項目到 Dictionary 物件。

語法

object.Add key, item

Add方法的語法有如下幾個單元:

單元 描述
Object 必要引數。一個 Dictionary 物件的名字。
Key 必要引數。與所加入的項目相關的關鍵字。
Item 必要引數。與所加入的關鍵字相關的項目。

請注意

如果該關鍵字已經存在,則產生一個錯誤。
所以,當使用ADD方法時若未先對關鍵字是否存在做檢查,若遇到已重複時就會產生錯誤。
所以我使用d(key)=item這樣的語法可避免這樣的麻煩。
所以當資料中,同樣關鍵字所參照到的內容若不相同時,此關鍵字儲位的內容將會被最後指定的值取代。
所以,dictionary物件的count屬性最簡單的說法就是,dictionary物件的關鍵字數量。

請注意該連結文章中語法的說明
dictionary_object.Add index, content
index就是索引值key
content就是內容item
d1(C) = ""這就是指定關鍵字C的那個儲位留空保存
所以你的解釋沒錯,若c不存在d1.COUNT就會加1
學海無涯_不恥下問

TOP

        靜思自在 : 人事的艱難與琢磨,就是一種考驗。
返回列表 上一主題