返回列表 上一主題 發帖

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

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

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

您好:
我是VBA初學者,現在需要把一份雜亂的原始報表,整理成所需型式的工作表(如附件)
請問除了土法煉鋼(出錯率較高)以外,能否有自動處理的方式,也當作我學習上的一個範本
我想這是一個浩大的工程。
感謝您附註:
1.各班可能會切成兩部分
2.各班選修科目也不相同
3.各班人數可能會改變
4.所需排列方式如SHEET4

score.rar (77.52 KB)

ASUS

回復 1# asus103
  1. Option Explicit
  2. Sub Ex()
  3.     Dim D(1) As Object, F As Range, MyClass$, F_Address$, Rng As Range, C, R, D_Key$, ARng As Range
  4.     Set D(0) = CreateObject("SCRIPTING.DICTIONARY")
  5.     Set D(1) = CreateObject("SCRIPTING.DICTIONARY")
  6.     With Sheets("Sheet1")
  7.         Set F = .Range("B:B").Find(what:="學 號", After:=.[b1], Lookat:=xlWhole)
  8.         If Not F Is Nothing Then
  9.             F_Address = F.Address
  10.             Do
  11.                 Set Rng = .Range(F, F.End(xlToRight).End(xlDown))
  12.                 MyClass = F.Offset(-2)
  13.                 For Each C In Rng.Columns(1).Cells
  14.                     If IsNumeric(C) Then
  15.                         D_Key = C & "," & C(1, 2) & "," & MyClass & "," & C(1, 3)
  16.                         D(0)(D_Key) = ""
  17.                         For R = 4 To Rng.Columns.Count
  18.                             If Rng(1, R) <> "" Then D(1)(D_Key & Rng(1, R)) = .Cells(C.Row, Rng(1, R).Column)
  19.                         Next
  20.                     End If
  21.                 Next
  22.                 Set F = .Range("B:B").FindNext(F)
  23.             Loop While F_Address <> F.Address
  24.             With Sheets("Sheet4")
  25.                 .UsedRange.Offset(1).Clear
  26.                 For Each R In D(0).KEYS
  27.                     Set ARng = .Range("A" & Rows.Count).End(xlUp).Offset(1)
  28.                     ARng.Resize(, 4) = Split(R, ",")
  29.                     For C = 5 To .[A1].End(xlToRight).Column
  30.                         If .Cells(1, C) <> "" Then ARng(1, C) = D(1)(R & .Cells(1, C))
  31.                     Next
  32.                 Next
  33.             End With
  34.         End If
  35.     End With
  36. End Sub
複製代碼

TOP

GBKEE:
非常感謝您!!!!
我現在馬上處理,先感謝您的費心
ASUS

TOP

回復 2# GBKEE
再一次感謝您
現在基本資料進來了
只是自己程度還不夠,尚無法完全看懂,我會再加油看懂它

那成績部分我若是用vlookup處理會遇到兩個問題
1.原資料並非完整區塊,中間有許多空白
2.各班及科目位置並不相同
請問有方法把成績轉移過來嗎?
謝謝
ASUS

TOP

回復 4# asus103
附檔上來看看

TOP

回復 5# GBKEE


GBKEE您好
原來的檔案中,即有成績的部分
只是各班(如5班以後)選修科目並不相同,
所以我無法自動判別取出

另,我的權限無法看到我自己的附檔
若檔案有問題煩請再告知
謝謝!!!
ASUS

TOP

回復 6# asus103
如圖 只要資料的B欄 內 [班級] 在 [學號] 的上2列  程式應可應付的

TOP

回復 3# 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) = d(Ky & .Cells(1, i))
  29.    Next
  30. r = r + 1
  31. Next
  32. End With
  33. End Sub
複製代碼
學海無涯_不恥下問

TOP

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

衷心感謝兩位版主的鼎力協助
我原以為恐怕需要很長的程式碼才能解決的
兩位版主化繁為簡的功力真令我佩服,而且是在這麼短的時間內
感激阿!!
我先使用了,之後我會努力看懂並學習的

尚有2個小問題請教:
1.若是把班級欄改為純數字,是否是手動即可
2.若想在未選修的位置上填上"-1",那應該在哪一行加上些甚麼?
謝謝
ASUS

TOP

回復 8# Hsieh
Hsieh大大您好
衷心感謝您的幫助

尚有2個小問題請教:
1.若是把班級欄改為純數字,是否是手動即可
2.若想在未選修的位置上填上"-1",那應該在哪一行加上些甚麼?
謝謝
ASUS

TOP

        靜思自在 : 【生命在呼吸間】佛陀說:「生命在呼吸間。」人無法管住自己的生命,更無法擋住死期,讓自己永住人間。既然生命去來這麼無常,我們更應該好好地愛惜它、利用它、充實它,讓這無常、寶貴的生命,散發它真善美的光輝,映照出生命真正的價值。
返回列表 上一主題