| ©«¤l5923 ¥DÃD13 ºëµØ1 ¿n¤À5986 ÂI¦W0  §@·~¨t²Îwin10 ³nÅ骩¥»Office 2010 ¾\ŪÅv150 ©Ê§O¨k ¨Ó¦Û¥xÆW°ò¶© µù¥U®É¶¡2010-5-1 ³Ì«áµn¿ý2022-1-23 
         
 | 
                
| ¥»©«³Ì«á¥Ñ GBKEE ©ó 2016-6-22 05:00 ½s¿è 
 ¦^´_ 3# bsy4life
 
 
 
 ¶¶«K½Ð±Ð¤@¤UcomboboxµLªk¥Î·Æ¹«ºu°Ê¬On«ç»ò§ï¤£¬O¦³¤è¦VÁä¥i¥Î
 
 work ªí³æ¼Ò²Õµ{¦¡½X¸Õ¸Õ¬Ý
 TextBoxProductNumber,TextBoxMachineNumber,ComboBoxProcess
 ¬Ò§ï¬° ComboBox ªº±±¨î¶µ ¨ä BoundColumn ÄÝ©Ê ½Ð«ü©w=1
 ½Æ»s¥N½XDim d As Object, Msg As Boolean  '³oªí³æ¼Ò²Õ ªº¨p¥ÎÅܼÆ
Private Sub UserForm_Initialize()
     TextBoxWorkOrderNumber = New_TextBoxWorkOrderNumber
     TextBoxProductNumber_MakeList
     TextBoxMachineNumber_MakeList
     Msg = True
End Sub
Private Sub TextBoxProductNumber_Change()
   With ComboBoxProcess  ' »sµ{ ±±¨î¶µ
        .Clear
        If TextBoxProductNumber.ListIndex > -1 Then
            If d(TextBoxProductNumber.Value).Rows.Count = 1 Then
                .AddItem d(TextBoxProductNumber.Value).Cells(2)  '®Æ¸¹¥u¦³¤@Ó
            Else
                .List = d(TextBoxProductNumber.Value).Columns(2).Value '¬Û¦P®Æ¸¹ ¤£¥u¤@Ó  ªº»sµ{½d³ò
            End If
            .ListIndex = 0
        End If
    End With
    xChicked
End Sub
Private Sub ComboBoxProcess_Change()
    LabeExceptTimeShow.Caption = ""
    LabelProcessTimeShow.Caption = ""
    With ComboBoxProcess
        If .ListIndex > -1 Then
            ' ***  d(TextBoxProductNumber.Value) ->Range ª«¥ó***
            LabeExceptTimeShow.Caption = d(TextBoxProductNumber.Value).Cells(.ListIndex + 1, "C")
            LabelProcessTimeShow.Caption = d(TextBoxProductNumber.Value).Cells(.ListIndex + 1, "D")
        End If
    End With
    xChicked
End Sub
Private Sub TextBoxMachineNumber_Change() '±a¤J¾÷¾¹«¬¸¹ªº¸ê®Æ
    With TextBoxMachineNumber
        LabelMachineShow.Caption = ""
        If .ListIndex > -1 Then LabelMachineShow.Caption = .List(.ListIndex, 1)
    End With
    xChicked
End Sub
Private Sub TextBoxWorkOrderNumber_Change()
    xChicked
End Sub
Private Sub CommandButtonSend_Click()
Dim Rng As Range, BtnCode As Integer
    If MsgBox("·s¼W¬£¤u  - " & TextBoxWorkOrderNumber, vbYesNo + 16 * 2, "¸ê®Æ°e¥X") = vbNo Then Exit Sub
    With Sheets("·s¼W¬£¤u")
        Set Rng = .Range("A1").End(xlDown)
        If Rng.Row = Rows.Count Then Set Rng = .Range("A1")
    End With
    With Rng.Offset(1)
        .Cells(1, 1) = TextBoxWorkOrderNumber.Value '¤u³æ½s¸¹
        .Cells(1, 2) = TextBoxProductNumber.Value '®Æ¸¹
        .Cells(1, 3) = ComboBoxProcess.Text  '»sµ{
        .Cells(1, 4) = TextBoxMachineNumber.Value  '¾÷¾¹½s¸¹
        .Cells(1, 5) = LabelMachineShow.Caption  '¾÷¾¹«¬¸¹
        .Cells(1, 6) = LabeExceptTimeShow.Caption '°£¥~¤u®É
        .Cells(1, 7) = LabelProcessTimeShow.Caption '³æ¦¸¤u®É
    End With
    TextBoxProductNumber.ListIndex = -1
    TextBoxMachineNumber.ListIndex = -1
    ComboBoxProcess.ListIndex = -1
    BtnCode = CreateObject("WScript.Shell").popup("¦¹Àɮפw¦Û°Ê¦sÀÉ", 1, Caption)
    ThisWorkbook.Save
    TextBoxWorkOrderNumber = New_TextBoxWorkOrderNumber
    BtnCode = CreateObject("WScript.Shell").popup("¤u³æ½s¸¹ " & TextBoxWorkOrderNumber, 2, Caption)
    TextBoxWorkOrderNumber.SetFocus
End Sub
Private Sub CommandButtonExit_Click()
    End
End Sub
Private Sub TextBoxProductNumber_MakeList()  '»sµ{¤u®É:®Æ¸¹¸ê®Æ
    Dim Rng As Range
    Set d = CreateObject("scripting.dictionary")   '¦r¨åª«¥ó
    Set Rng = Sheets("»sµ{¤u®É").Range("A2")
    Do While Rng <> ""
        If d.EXISTS(Rng.Value) Then
            Set d(Rng.Value) = Union(Rng.Resize(, 4), d(Rng.Value)) '®Æ¸¹, »sµ{, °£¥~¤u®É,³æ¦¸¤u®É
        Else
            Set d(Rng.Value) = Rng.Resize(, 4)      '®Æ¸¹, »sµ{, °£¥~¤u®É,³æ¦¸¤u®É
        End If
        Set Rng = Rng.Offset(1)
    Loop
    With TextBoxProductNumber
        .List = d.KEYS
        .ListIndex = 0
    End With
End Sub
Private Sub TextBoxMachineNumber_MakeList()  'List ¥]§t( ¾÷¾¹½s¸¹ , «¬¸¹)
        With Sheets("¾÷¾¹«¬¸¹")
                TextBoxMachineNumber.List = .Range("A2:B" & .Range("A1").End(xlDown).Row).Value
        End With
        TextBoxMachineNumber.ListIndex = 0
End Sub
Private Function New_TextBoxWorkOrderNumber() As String '·s¼W ¤u³æ¸¹½X  ®æ¦¡: XXX-1234567890
    Dim New_No As Variant
    With Sheets("·s¼W¬£¤u").Range("A1").End(xlDown)
            If .Row > 1 And .Cells <> "" Then
                New_No = Split(.Cells, "-")
                New_No(1) = Format(Val(New_No(1)) + 1, "0000000000")
                New_TextBoxWorkOrderNumber = New_No(0) & "-" & New_No(1)
            End If
    End With
End Function
Private Sub xChicked()  '¨¾§bµ{¦¡
    Dim BtnCode As Integer, xOrder, Msg As Boolean
    With CommandButtonSend
        .Enabled = TextBoxProductNumber.ListIndex > -1 And ComboBoxProcess.ListIndex > -1 And TextBoxMachineNumber.ListIndex > -1
        .Enabled = .Enabled And Len(Trim(TextBoxWorkOrderNumber)) = 14
        If Len(Trim(TextBoxWorkOrderNumber)) = 14 Then
             xOrder = Split(TextBoxWorkOrderNumber, "-")
            If UBound(xOrder) = 0 Then Msg = True
            If UBound(xOrder) = 1 Then
                If Len(xOrder(0)) <> 3 Then Msg = True   '«e¤T½X
                If Len(xOrder(1)) <> 10 Then Msg = True '«á¤Q½X
                If Len(xOrder(1)) = 10 And IsNumeric(xOrder(1)) = False Then Msg = True '«á¤Q½X»Ý¬°¼Æ¦r
            End If
            If Msg Then BtnCode = CreateObject("WScript.Shell").popup("¤u³æ½s¸¹ ¿ù»~  " & TextBoxWorkOrderNumber & vbLf & "¦p :xxx-1234567890", 2, Caption)
            .Enabled = .Enabled And Msg = False
        End If
    End With
End Sub
 | 
 |