- ©«¤l
- 1537
- ¥DÃD
- 40
- ºëµØ
- 0
- ¿n¤À
- 1561
- ÂI¦W
- 0
- §@·~¨t²Î
- Windows 7
- ³nÅ骩¥»
- Excel 2010 & 2016
- ¾\ŪÅv
- 100
- ©Ê§O
- ¨k
- ¨Ó¦Û
- ¥xÆW
- µù¥U®É¶¡
- 2020-7-15
- ³Ì«áµn¿ý
- 2025-11-6
|
¦^´_ 165# 198188
1¡^ Form ¬O ®Ú¾Ú ¥»ÀÉ Part List ªº A Äæ ¥[¤u¥ó½s¸¹ ©M G Äæ ³Æª` ¨Ó¾É¥X Form
«e½úªºµ{¦¡¡A³s Frame per Dwg ¤]¾É¥X Form ¤F¡A³o³¡¤À¤£»Ýn (¥Hªþ¥óªº¨Ò¤l¡AWS-T, WA-W, FS-W, FG-W, FA-W ùرªº½s¸¹ ¬O¤£¦bPart List ùر¡A©Ò¥H¤£n¨îªí)
«e½ú¨S¦³¥Î¦æ·~¸Ü³N»¡©ú¬°¤°»ò¤£»Ýn,¥u¯à¥Î¦r±¤Wªº·N«ä²q»Ý¨D,¬A©·()¸Ìªº·N¸qµLªk²z¸Ñ,¥H¤U¤è®×½Ð°Ñ¦Ò
Option Explicit
Public A, Z, R&, W, L, i&, Brr, Mrr, Q, Drr, j%, MyPath$
Sub Form()
Dim Arr, Crr(1 To 100000, 1 To 18), xW$, S, T$, T2$, Ts, xFile$, xBook As Workbook, Re
Application.ScreenUpdating = False
Application.DisplayAlerts = False
MyPath = ThisWorkbook.Path & "\"
xFile = "Data Base.xlsx"
On Error Resume Next
Set xBook = Workbooks(xFile)
If xBook Is Nothing Then
Set xBook = Workbooks.Open(MyPath & xFile, , True, , "")
Re = True: ThisWorkbook.Activate
End If
On Error GoTo 0
Mrr = xBook.Sheets("Material").UsedRange
If Re = True Then xBook.Close 0
Call RuleRun
For i = 2 To UBound(Mrr): Z(Mrr(i, 3) & "/m") = i: Next
For i = Worksheets.Count To 1 Step -1
If Z(Sheets(i).Name & "/s") <> "" Then Sheets(i).Delete
Next
If Sheets("Part List").FilterMode = True Then Sheets("Part List").ShowAllData
With Range(Sheets("Part List").[P1], Sheets("Part List").[A65536].End(3)(2))
With .Columns(15): .Cells = "=ROW()": .Value = .Value: End With
Brr = .Value
ReDim Arr(1 To UBound(Brr) - 1, 1 To 1)
For i = 2 To UBound(Brr)
T = Left(Brr(i, 1), 2) & "-" & Brr(i, 7)
If InStr("Y-OWT", Right(T, 1)) Then Arr(i - 1, 1) = Z(T)
Next
.Cells(2, 16).Resize(UBound(Brr) - 1, 1) = Arr
.Sort KEY1:=.Item(16), Order1:=1, Header:=1
Brr = .Value
.Sort KEY1:=.Item(15), Order1:=1, Header:=1
.Cells(1, 15).Resize(, 2).EntireColumn.Delete
A = Crr
For i = 2 To UBound(Brr) - 1
If Brr(i, 16) = "" Then Exit For Else T = Brr(i, 16)
R = R + 1: A(R, 1) = R: Run Replace(Z(T & "/s"), " ", "_")
If T <> Brr(i + 1, 16) Then
Sheets(Z(T & "/s")).Copy Before:=Sheets(1)
ActiveSheet.Name = T
With Cells(Z(Z(T & "/s") & "/UR"), 1).Resize(R, Z(Z(T & "/s") & "/UC"))
.Value = A
.Borders.LineStyle = xlContinuous
ActiveSheet.PageSetup.PrintArea = Range([A1], .Cells).Address
End With
With Range(Z(Z(T & "/s") & "/V1")): .Value = Z(T & "/EC"): .ShrinkToFit = True: End With
With Range(Z(Z(T & "/s") & "/V2")): .Value = Z(T & "/ER"): .ShrinkToFit = True: End With
A = Crr: R = 0
End If
Next
End With
ThisWorkbook.Activate
Set Z = Nothing
Erase Arr, Brr, Crr, A, Mrr
End Sub |
|