入库单表格制作(excel采购入库也能这么简单)

2024-10-25 15:15:37

嘿,朋友们,你们还在为采购入库时录入电脑时,怕录错而烦恼吗?以后采购入库再也不用那么麻烦了。你只需要动动手指,在屏幕上选几下,不管是单个商品还是一堆货物,都能轻松搞定。单行录入?没问题!批量录入?也是小菜一碟!再也不用担心手酸眼花了。

看看下面动态的效果:


现在就如何把记录添加到明细表中去的步骤一一展现:

步骤一:先要有三张工作表

准备三张表格:采购入库单、入库明细表、基本信息,格式如图所示:





步骤二:商品信息窗体的制作



第一步:在“开发工具”选项卡中,找到并点击“Visual Basic”按钮,这将打开VBA编辑器(也称为VBE,Visual Basic Editor)窗口


如果找不到VBA的“开发工具”菜单,通常是因为该菜单在Excel的默认设置中并未被显示出来:

  1. 点击Excel左上角的“文件”菜单,然后选择“选项”以打开Excel选项窗口。
  2. 在Excel选项窗口中,选择“自定义功能区”选项。
  3. 在右侧的自定义功能区列表中,找到并勾选“开发工具”复选框。
  4. 点击“确定”按钮,关闭Excel选项窗口。此时,“开发工具”菜单应该已经出现在Excel的菜单栏中了。




第二步:制作商品信息窗体

(1)鼠标右击Thisbook------插入------用户窗体

(2)然后用户窗体属性这里把caption改成商品信息,名称改成Wpxxfm

用工具箱画出窗体上的控件:


把列表框的名称改为:ListBox_product

(3)然后右击窗体,选查看代码:


(4)把以下代码拷贝进去:

窗体初始化代码

Private Sub UserForm_Initialize()

Dim ws As Worksheet

Dim columnWidths As String

Set ws = ThisWorkbook.Worksheets("基本信息") '指定工作表

'为列表框置项目

With Me.ListBox_product

.Clear

.RowSource = ws.Name & "!A1:E" & ws.Cells(Rows.count, 1).End(xlUp).Row

columnWidths = "50;100;100;60;50"

.columnWidths = columnWidths

.ColumnCount = 5

.Font.Size = 10

End With

End Sub


以下是确定按钮的代码:把入库单写到入库明细表中

Private Sub CommandButton1_Click()

Dim ws As Worksheet

Dim nextrow As Variant

Dim i As Integer

Dim j As Integer

Set ws = ThisWorkbook.Worksheets("采购入库单")

nextrow = ws.Cells(ws.Rows.count, 2).End(xlUp).Row

With Me.ListBox_product

For i = 0 To .ListCount - 1

If .Selected(i) Then

ws.Cells(nextrow + 1, 2).Value = nextrow - 3

For j = 1 To .ColumnCount

ws.Cells(nextrow + 1, j + 2) = .List(i, j - 1)

Next j

nextrow = nextrow + 1

End If

Next i

End With

Unload Me

End Sub

步骤三:输入相应的代码

(1)在sheet1工作表写入以下代码

Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)

If Target.Column = 3 And Target.Row > 4 Then

Wpxxfm.Show 0

Cancel = True

End If

End Sub


(2)增加添加记录代码


先插入模块,然后在模块里添加这段代码:



Sub 添加记录()

Dim ws As Worksheet, ws3 As Worksheet

Dim i%, j%, irows%, rkirows%

Set ws = Worksheets("采购入库单")

Set ws3 = Worksheets("入库明细表")

irows = ws.Cells(Rows.count, 2).End(xlUp).Row

If irows > 4 Then

ReDim arr(1 To irows - 4, 1 To 11)

For i = 1 To UBound(arr)

arr(i, 1) = ws.Range("C3").Value

arr(i, 2) = ws.Range("F3").Value

For j = 3 To 10

arr(i, j) = ws.Cells(i + 4, j)

Next j

Next i

irows = ws3.Cells(Rows.count, 1).End(xlUp).Row

ws3.Range("A" & irows + 1).Resize(UBound(arr, 1), UBound(arr, 2)) = arr

End If

Call 清空

End Sub

同样增加个模块,把清空按钮代码放进去



步骤四:添加按钮跟清空按钮的制作

先插入形状:圆角柜形(如图)



再把圆角矩形上的文字改成"添加按钮"这四个字


再对按钮指定宏:


添加按钮指定宏完成后,用同样的步骤把再做一个清空按钮并指定宏。

以上的步骤,就能全部完成输入记录时自动添加到入库明细表中。最令人兴奋的是,所有录入的信息将自动保存到入库明细表中,无需担心数据丢失或遗漏。