返回列表 上一主題 發帖

日數統計

日數統計

如何在(I1:I24)統計一大堆日期(A1:F9)中的日數 統計日數.rar (1.95 KB)

本帖最後由 ANGELA 於 2010-11-15 15:03 編輯

i1=SUMPRODUCT((YEAR($A$1:$F$9)=--LEFT(H1,4))*(MONTH($A$1:$F$9)=IF(MOD(ROW(),12),MOD(ROW(),12),12)))

TOP

=COUNTIF($A$1:$F$9,">"&DATE(LEFT(H1,4),MID(H1,6,LEN(H1)-6),))-COUNTIF($A$1:$F$9,">"&DATE(LEFT(H1,4),MID(H1,6,LEN(H1)-6)+1,))
知之為知之,不知為不知,誠實也!

TOP

統計日數.rar (2.2 KB)

TOP

越來越精簡了
知之為知之,不知為不知,誠實也!

TOP

真的是太神了 感謝
solomon

TOP

本帖最後由 Andy2483 於 2023-3-24 10:25 編輯

回復 1# mmggmm


    謝謝論壇,謝謝前輩發表此主題與範例
後學藉此主題練習陣列與字典,學習VBA的解決方案如下,請前輩參考

執行前:


執行結果:



Option Explicit
Sub TEST()
Dim Brr, T, Y, Z, A, xR As Range
'↑宣告變數:(Brr,T,Y,Z,A)是通用型變數,(xR,xU)是儲存格變數
Set Y = CreateObject("Scripting.Dictionary")
'↑令Y這通用型變數是 字典
Set Z = CreateObject("System.Collections.ArrayList")
'↑令Z這通用型變數是 使用大小會視需要動態增加的陣列
Set xR = [A1:F9]: Brr = xR
'↑令xR這儲存格變數是 [A1:F9]儲存格,
'令Brr這通用型變數是 二維陣列,以xR變數儲存格值帶入陣列裡

For Each A In Brr
'↑設逐項迴圈!令A這通用型變數是 Brr陣列裡的一個陣列值
   A = Format(A, "yyyy" & "年" & "mm")
   '↑令A變數是 四位數的數字碼年 連接"年",再連接2碼月份成的新字串
   If A <> vbNullString And Not Z.contains(A) Then Z.Add (A)
   '↑如果A變數不是 長度為零的字串,而且A變數不在Z陣列裡?
   '如果條件成立就把 A變數納入Z陣列裡

Next
Z.Sort
'↑令Z陣列做順排序
For Each A In Z: Y(A) = 0: Next
'↑設逐項迴圈!將Z陣列裡的值當key,item是0,納入Y字典裡
For Each A In xR
'↑設逐項迴圈!令A變數是xR變數儲存格中的一格
   A = Format(A, "yyyy" & "年" & "mm")
   '↑令A變數是 四位數的數字碼年 連接"年",再連接2碼月份成的新字串
   Y(A) = Y(A) + 1
   '↑令A變數值轉數值當key,item是 item自身值+1
Next
[L:M].ClearContents: [L1:M1] = [{"月份", "天數"}]
'↑令[L:M]儲存格清除內容:令[L1:M1]這兩格以↑陣列兩字串帶入
[L2].Resize(Y.Count, 1) = Application.Transpose(Y.keys)
'↑令[L2]擴展向下Y字典key數量數的儲存格,
'以Y字典keys轉置後帶入儲存格

[M2].Resize(Y.Count, 1) = Application.Transpose(Y.items)
'↑令[M2]擴展向下Y字典key數量數的儲存格,
'以Y字典items轉置後帶入儲存格

Set Y = Nothing: Set Z = Nothing: Set xR = Nothing
Erase Brr
'↑令釋放變數
End Sub
用行動裝置瀏覽論壇學習很方便,謝謝論壇經營團隊
請大家一起上論壇來交流

TOP

google"EXCEL迷"  blog  或google網址:https://hcm19522.blogspot.com/

TOP

        靜思自在 : 人生不一定球球是好球,但是有歷練的強打者,隨時都可以揮棒。
返回列表 上一主題