返回列表 上一主題 發帖

[發問] 如何判定料號+批號其生產天數

[發問] 如何判定料號+批號其生產天數

Dear all,
圖表說明如下圖。是否有公式可以帶出我想要的結果,現況是以人工計算,常會出錯
Thank you.

133.rar (8.86 KB)

Noname.jpg
2021-11-19 13:33
Just do it.

回復 1# jsc0518

請測試看看,謝謝
Sub test()
Dim Arr, xD, Brr(), T$, T1$, i&, n%, m%
Set xD = CreateObject("Scripting.Dictionary")
Arr = Range([a1], [c65536].End(3))
ReDim Brr(1 To UBound(Arr), 1 To 3)
For i = 2 To UBound(Arr)
    T = Arr(i, 2) & "|" & Arr(i, 3)
    T1 = Arr(i, 1) & "|" & Arr(i, 2) & "|" & Arr(i, 3)
    If xD.Exists(T) Then
        m = xD(T)
        If Not xD.Exists(T1) Then Brr(m, 3) = Brr(m, 3) + 1
    Else
        n = n + 1: xD(T) = n: xD(T1) = n
        Brr(n, 1) = Arr(i, 2)
        Brr(n, 2) = Arr(i, 3)
        Brr(n, 3) = 1
    End If
Next
With Range("g2").Resize(n, 3)
    .Value = Brr
    .Sort Key1:=.Item(1), Order1:=1, _
          Key2:=.Item(2), Order2:=1, Header:=2
End With
End Sub

TOP

隨意窩 "EXCEL迷"  blog  或https://blog.xuite.net/hcm19522/twblog
已收集8500篇 EXCEL函數

TOP

回復 3# hcm19522

Dear hcm19522,

您好!感謝您的熱心指導與回覆。

與您請教,當公式我改成

=SUMPRODUCT((B$2:B$20000&C$2:C$20000=G2&H2)/COUNTIFS(A:A,A$2:A$20000,B:B,B$2:B$20000,C:C,C$2:C$20000))

它就有點類似當機一樣不會執行,是否是20000欄位太多了?

Thank you.
Just do it.

TOP

回復 2# samwang
Dear samwang,
晚上好!感謝您的熱心回覆與指導歐
剛剛測試一下與法式OK的,感恩
我等等會在小改一下您的語法,有問題再與您請教歐!
Thank you.
Just do it.

TOP

回復 2# samwang
Dear samwang,
我修改了語法,出現400錯誤。
說明一下,我把原本A~C欄位的工作表命名為"01"
而原本於G~I欄位我把它放在"02"(工作表名稱)
再請您指導我


語法更改如下

Sub test()
Dim Arr, xD, Brr(), T$, T1$, i&, n%, m%
Set xD = CreateObject("Scripting.Dictionary")
Arr = Range([01!a1], [01!c65536].End(3))
ReDim Brr(1 To UBound(Arr), 1 To 3)
For i = 2 To UBound(Arr)
    T = Arr(i, 2) & "|" & Arr(i, 3)
    T1 = Arr(i, 1) & "|" & Arr(i, 2) & "|" & Arr(i, 3)
    If xD.Exists(T) Then
        m = xD(T)
        If Not xD.Exists(T1) Then Brr(m, 3) = Brr(m, 3) + 1
    Else
        n = n + 1: xD(T) = n: xD(T1) = n
        Brr(n, 1) = Arr(i, 2)
        Brr(n, 2) = Arr(i, 3)
        Brr(n, 3) = 1
    End If
Next

With Range([02!g2]).Resize(n, 3)
    .Value = Brr
    .Sort Key1:=.Item(1), Order1:=1, _
          Key2:=.Item(2), Order2:=1, Header:=2
End With
End Sub
Just do it.

TOP

J2 =COUNT(0/FREQUENCY((G2=B$2:B$99)*(H2=C$2:C$99)*A$2:A$99,A$2-2+ROW($1:$99)))-1
下拉
{...} 表示需要用 CTRL+SHIFT+ENTER 三鍵輸入公式

TOP

回復 7# ML089
Dear ML089,
晚上好!感謝您的熱心回復與指導
測試可以使用歐!
Thank you.
Just do it.

TOP

本帖最後由 jsc0518 於 2021-11-19 21:46 編輯

回復 7# ML089
Dear ML089,
剛剛試了一下,發現在相同日期有出現2次
在公式也是累計到有2次

但我希望是當日若有出現2次以上,公式幫我判斷算1次


Thank you.
Just do it.

TOP

回復 6# jsc0518


方便附件檔案嗎?
謝謝

TOP

        靜思自在 : 為人處世要小心細心,但不要「小心眼」。
返回列表 上一主題