VBA 库存管理案例

一、 查找

' 调用工作表函数查找

Sub t1() '判断是否存在,并查找所在行数
Dim hao As Integer
Dim icount As Integer
icount = Application.WorksheetFunction.CountIf(Sheets("库存明细表").[b:b], [g3])
If icount > 0 Then
    MsgBox "该入库单号码已经存在,请不要重复输入"
    MsgBox Application.WorksheetFunction.Match([g3], Sheets("库存明细表").[b:b], 0)
    End If

End Sub



' 使用find 方法

Sub t2()
Dim r As Integer, r1 As Integer
Dim icount As Integer
icount = Application.WorksheetFunction.CountIf(Sheets("库存明细表").[b:b], [g3])
If icount > 0 Then
    r = Sheets("库存明细表").[b:b].Find(Range("g3"), lookat:=xlwbole).Row ' 查找号码第次出现的位置
    r1 = Sheets("库存明细表").[b:b].Find([g3], , , , , xlPrevious).Row  ' xlPrevious 向后查找
    MsgBox r & ":" & r1
    End If

End Sub



Sub t3()  '返回最下一行的非空行的行数

    MsgBox Sheets("库存明细表").Cells.Find("*", , , , , xlPrevious).Row
    

End Sub

 

 

案例 :

输入

Sub 输入()

Dim c As Integer  ' 号码在库存表中的个数
Dim r As Integer   ' 入库单的数据行数
Dim cr As Integer  ' 库存明细表中的第一个空行的行数

With Sheets("库存明细表")
    c = Application.CountIf([b:b], Range("g3"))
    If c > 0 Then
        MsgBox "该单据号码已经存在!请不要重复输入"
        Exit Sub
    Else
        r = Application.CountIf(Range("b6:b10"), "<>")
        cr = .[b65536].End(xlUp).Row + 1
        .Cells(cr, 1).Resize(r, 1) = range("e3")
        .Cells(cr, 2).Resize(r, 1) = range("g3")
        .Cells(cr, 3).Resize(r, 1) = range("c3")
        .Cells(cr, 4).Resize(r, 6) = Cells(6, 2).Resize(r, 6).Value
        MsgBox "输入已完成"
    End If
 End With
End Sub

 

查找

Sub 查找()

Dim c As Integer  ' 号码在库存表中的个数
Dim r As Integer   ' 入库单的数据行数

With Sheets("库存明细表")
    c = Application.CountIf([b:b], Range("g3"))
    If c = 0 Then
        MsgBox "该单据号码不存在!"
        Exit Sub
    Else
        r = .[b:b].Find(Range("g3"), , , , , xlNext).Row
        Range("c3") = .Cells(r, 3)
        Range("e3") = .Cells(r, 1)
        Cells(6, 2).Resize(e, 5) = Cells(r, 4).Resize(e, 5).Value
        MsgBox "查找已完成"
    End If
End With

End Sub

删除

Sub 删除()
Dim c As Integer    ' 号码在库存表中的个数
Dim r As Integer    ' 入库单的数据行数

With Sheets("库存明细表")
    c = Application.CountIf([b:b], Range("g3"))
    If c = 0 Then
        MsgBox "该单据号码不存在!"
        Exit Sub
    Else
        r = .[b:b].Find(Range("g3"), , , , , xlNext).Row
        .Range(r & ":" & c + r - 1).Delete
        MsgBox "删除成功"
    End If
End With
End Sub

 

修改

Sub 修改()
Call 删除
Call 输入
End Sub

 

posted @ 2020-03-02 11:02  heshun  阅读(1802)  评论(0编辑  收藏  举报