→ soyoso: 以a(i,1),a欄的值做為d的索引值,並於d(a(i,1))=d(a(i,1) 03/29 00:02
→ soyoso: )+a(i,2)做累加,a(i,2)為b欄 03/29 00:03
→ soyoso: 第二個為於range("e2:e25001")處以公式=if(d2=d1,c2+e1,c2 03/29 00:23
→ soyoso: 將累加的最後一筆,以排序方式d欄小至大,e欄大至小移至分 03/29 00:29
→ soyoso: 組的第一筆 03/29 00:29
→ soyoso: 原文有寫到"不是應該要在合併完AB欄位後就要先排序一次" 03/29 00:32
→ soyoso: 應是備註處已有寫到The data is already sorted on 03/29 00:33
→ soyoso: columns A AND B的原因,故巨集內無再多加入 03/29 00:34
→ soyoso: 個人覺得下方巨集不一定會輸出正確,例如a欄9,b欄99合併 03/29 00:37
→ soyoso: 為999,a欄99,b欄9,合併也是999 03/29 00:38
→ soyoso: 就會加總起來了,這和sumifs的判斷上不同的 03/29 00:39
→ heavendemon: 謝謝so大 指點 關於陣列的部分 小弟我實測後結果也是 03/29 00:44
→ heavendemon: 和sumif函數結果不同 我用監看陣列後也看不明白 03/29 00:44
→ heavendemon: a(1,1)並不是A1的值 不過是有出現在A欄 但a(1,2)的值 03/29 00:46
→ heavendemon: 不是B1外 根本沒有出現在原本的range裡 是小弟理解錯 03/29 00:46
→ heavendemon: 誤還是這個陣列本身就有問題 如果so大 方便 可否用陣 03/29 00:47
→ heavendemon: 列示範 sumifs的寫法 如果是要兩個criteria就會變成 03/29 00:49
→ heavendemon: 三欄的陣列? a(i,1),(i,2),(i,3) 03/29 00:49
→ heavendemon: 或有任何加速sumifs在VBA的方法 幾千筆跑下來很費時 03/29 00:58
→ heavendemon: 另外我發現這兩個方法應該都是用本身欄位中的值當作 03/29 01:14
→ soyoso: 如a指定以a1:b1起的範圍的話a(1,1)應是a1的值,a(1,2)為b1 03/29 01:15
→ heavendemon: criteria 但我的函數是將跨工作頁的cell當criteria 03/29 01:16
→ heavendemon: 所以才不能用樞紐分析 不知道這樣是不是還可以用陣列 03/29 01:16
→ heavendemon: 的方式執行出sumifs的效果 03/29 01:17
→ soyoso: 其他字元來區別,再將d欄排序的話,是否可以排除回文內所 03/29 01:28
→ soyoso: 提到的問題呢? 03/29 01:29
→ soyoso: 如要以上方巨集改為sumifs的話,可以 03/29 01:37
→ soyoso: 函數做為比對而已 03/29 01:38
→ heavendemon: 所以在dictionary裡面 前面一定是key 後面就是item 03/29 10:34
→ heavendemon: d(a(i,1)&"_"&a(i,2))就是一定是對應到a(i,3) 03/29 10:37
→ heavendemon: 不知道我這樣理解有沒有錯 非常感謝so大這麼晚還解答 03/29 10:38
→ soyoso: 理解上會以d(a(i,1)&"_"&a(i,2))會對應到a(i,1)&"_"&a(i,2 03/29 10:51
→ soyoso: )並將a(i,3)累加進去,看是否也和原po回文的理解上相同 03/29 10:52
→ heavendemon: 了解 另外我要將不連續的range放到陣列裡面 先使用 03/29 11:38
→ heavendemon: application.union 再丟進陣列 但陣列只讀取到第一個 03/29 11:39
→ heavendemon: range 陣列一定要連續range沒有其他辦法?或是另開一 03/29 11:40
→ heavendemon: 陣列去除存另外的range ? 03/29 11:41
→ soyoso: 不連續方式想到的是迴圈或以Array的方式 03/29 12:03
※ 編輯: heavendemon (47.89.55.16), 03/29/2017 15:14:04
→ heavendemon: on error resume next 之後在B欄某一criteria的結果 03/29 16:03
→ soyoso: 有錯誤訊息? 03/29 16:03
→ heavendemon: 是錯的 不過是有順利跑完 就是16140.41這個crieria 03/29 16:04
→ heavendemon: 結果和sumifs不同 03/29 16:05
→ heavendemon: 錯誤是型態不符合 03/29 16:06
→ soyoso: sumarr方面是否為文字類型呢? 03/29 16:16
→ soyoso: d內,如又有符合a、b欄時,進行累加上就會出現型態不符合 03/29 16:19
→ heavendemon: 比對後,速度反而更慢 平均100row40秒 這個比對的部 03/29 18:55
→ heavendemon: 有沒有比較聰明效率的寫法 感覺繞了一大圈回到原點.. 03/29 18:56
→ soyoso: 將判斷的結果先以丟進變數array內,迴圈結束後再一次,以 03/29 19:24
→ soyoso: range=變數的方式寫入 03/29 19:25
→ soyoso: 寫入上應會用到工作表函數transpose 03/29 19:28
→ heavendemon: 小弟對陣列真的不熟悉 不知道能不能有簡單的示範參考 03/29 20:10
→ soyoso: 原文上面的巨集內Range("E1:E" & n) = u和上面的迴圈,就 03/29 20:51
→ soyoso: 約是回文內的意思 03/29 20:51
非常感謝so 大不厭其煩解答
我最後用了錄製巨集的方式取得原本sumifs函數的formulaR1C1格式
直接將R1C1的函數丟到指定的range範圍
最後把函數取代成值
達到每100rows低於一秒的效率
花了很久的時間 才回頭發現最簡單的方法
希望能給有遇到函數公式太多導致原始資料更新耗時的朋友
一些參考和幫助
※ 編輯: heavendemon (47.89.55.16), 03/30/2017 18:10:19