我正在爲工作創建一個項目跟蹤器,並且需要幫助縮短代碼。每個製造商都有自己的表格。我有一個用戶表單,項目經理輸入數據。每個製造工作表都是相同的,並且鏈接到用戶表單的偏移量也是相同的。如何縮短偏移代碼VBA
請參閱下面的代碼。我是編碼新手,可以使用一些幫助。
'A&R 5X9N
If Me.CB7.Value = "A&R" And Me.CB23.Value = "5x9N" Then
rowcount = Worksheets("A&R").Range("c3").CurrentRegion.Rows.Count
With Worksheets("A&R").Range("c1")
'PROJECT
.Offset(rowcount, 0) = Me.CB1.Value
.Offset(rowcount, 1) = Me.TB2.Value
.Offset(rowcount, 2) = Me.TB3.Value
.Offset(rowcount, 3) = Me.CB4.Value
.Offset(rowcount, 4) = Me.CB7.Value
.Offset(rowcount, 5) = Me.TB1.Value
'FINISH DATES
.Offset(rowcount, 7) = Me.TB23.Value
.Offset(rowcount, 8) = Me.TB24.Value
.Offset(rowcount, 9) = Me.TB25.Value
.Offset(rowcount, 10) = Me.TB26.Value
.Offset(rowcount, 11) = Me.TB27.Value
.Offset(rowcount, 12) = Me.TB28.Value
.Offset(rowcount, 13) = Me.TB29.Value
'PRODUCTION
.Offset(rowcount, 14) = Me.TB8.Value
.Offset(rowcount, 15) = Me.TB9.Value
.Offset(rowcount, 16) = Me.TB10.Value
.Offset(rowcount, 17) = Me.TB11.Value
.Offset(rowcount, 18) = Me.TB12.Value
.Offset(rowcount, 19) = Me.TB13.Value
.Offset(rowcount, 20) = Me.TB14.Value
'ASSETS
.Offset(rowcount, 21) = Me.TB16.Value
.Offset(rowcount, 22) = Me.TB17.Value
.Offset(rowcount, 23) = Me.TB18.Value
.Offset(rowcount, 24) = Me.TB19.Value
.Offset(rowcount, 25) = Me.TB20.Value
.Offset(rowcount, 26) = Me.TB21.Value
.Offset(rowcount, 27) = Me.TB22.Value
.Offset(rowcount, 28) = Me.CB23.Value
.Offset(rowcount, 29) = Me.CB24.Value
.Offset(rowcount, 30) = Me.CB25.Value
.Offset(rowcount, 31) = Me.CB26.Value
.Offset(rowcount, 32) = Me.CB27.Value
End With
End If
'A&R 5X10N
If Me.CB7.Value = "A&R" And Me.CB23.Value = "5x10N" Then
rowcount = Worksheets("A&R").Range("AM3").CurrentRegion.Rows.Count
With Worksheets("A&R").Range("AM1")
'PROJECT
.Offset(rowcount, 0) = Me.CB1.Value
.Offset(rowcount, 1) = Me.TB2.Value
.Offset(rowcount, 2) = Me.TB3.Value
.Offset(rowcount, 3) = Me.CB4.Value
.Offset(rowcount, 4) = Me.CB7.Value
.Offset(rowcount, 5) = Me.TB1.Value
'FINISH DATES
.Offset(rowcount, 7) = Me.TB23.Value
.Offset(rowcount, 8) = Me.TB24.Value
.Offset(rowcount, 9) = Me.TB25.Value
.Offset(rowcount, 10) = Me.TB26.Value
.Offset(rowcount, 11) = Me.TB27.Value
.Offset(rowcount, 12) = Me.TB28.Value
.Offset(rowcount, 13) = Me.TB29.Value
'PRODUCTION
.Offset(rowcount, 14) = Me.TB8.Value
.Offset(rowcount, 15) = Me.TB9.Value
.Offset(rowcount, 16) = Me.TB10.Value
.Offset(rowcount, 17) = Me.TB11.Value
.Offset(rowcount, 18) = Me.TB12.Value
.Offset(rowcount, 19) = Me.TB13.Value
.Offset(rowcount, 20) = Me.TB14.Value
'ASSETS
.Offset(rowcount, 21) = Me.TB16.Value
.Offset(rowcount, 22) = Me.TB17.Value
.Offset(rowcount, 23) = Me.TB18.Value
.Offset(rowcount, 24) = Me.TB19.Value
.Offset(rowcount, 25) = Me.TB20.Value
.Offset(rowcount, 26) = Me.TB21.Value
.Offset(rowcount, 27) = Me.TB22.Value
.Offset(rowcount, 28) = Me.CB23.Value
.Offset(rowcount, 29) = Me.CB24.Value
.Offset(rowcount, 30) = Me.CB25.Value
.Offset(rowcount, 31) = Me.CB26.Value
.Offset(rowcount, 32) = Me.CB27.Value
End With
End If
所以你想讓它更有效率? – PMARINA
通過使用[Arrays](https://msdn.microsoft.com/en-us/library/office/gg264224.aspx)和[loops]進行優化(https://www.tutorialspoint.com/vba/vba_for_loop.htm )。這不會解決你所有的問題,但它應該可以幫助你編寫代碼。 – PMARINA