ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 541|回复: 17

[求助] 代码不知道哪里出问题了,请老师帮忙看看。

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-5-21 10:33 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 dbg111222 于 2024-5-21 10:42 编辑

从收入表中获取数据,验收记录表中1-8行不变,第9行开始根据收入表内容自动添加行数,最下面保留6行内容不变。请老师帮忙看看,代码运行后内容没有从收入表中获取,最后6行内容也不见了。模块3。

电子台账模板5.zip

48.98 KB, 下载次数: 23

TA的精华主题

TA的得分主题

发表于 2024-5-21 10:48 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
UsedRange.Offset(8).ClearContents被这句代码删除了

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-5-21 11:11 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
Qs18 发表于 2024-5-21 10:48
UsedRange.Offset(8).ClearContents被这句代码删除了

能按照我的要求给修改一下吗,谢谢!

TA的精华主题

TA的得分主题

发表于 2024-5-21 12:13 | 显示全部楼层
dbg111222 发表于 2024-5-21 11:11
能按照我的要求给修改一下吗,谢谢!

不知道您要查询数据的条件,还是全部的数据

TA的精华主题

TA的得分主题

发表于 2024-5-21 12:13 | 显示全部楼层
预设100行空白行,写入数据后隐藏多余的行。

电子台账模板5.zip

53.82 KB, 下载次数: 18

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-5-21 13:07 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
半百 发表于 2024-5-21 12:13
预设100行空白行,写入数据后隐藏多余的行。

非常感谢,但是我的表头第4第5行数据怎么带入呢?

TA的精华主题

TA的得分主题

发表于 2024-5-21 13:09 | 显示全部楼层
半百 发表于 2024-5-21 12:13
预设100行空白行,写入数据后隐藏多余的行。

您合并的单元格太多,我写了增加行数的过程这个是根据您的需要自己可以输入需要的行数,另外就是删除的空白行数两个过程。可以根据您的业务逻辑call一下就可以。您自己的业务逻辑我没有动。

TA的精华主题

TA的得分主题

发表于 2024-5-21 13:12 | 显示全部楼层
Sub 插入空白行()
Application.DisplayAlerts = False
Application.ScreenUpdating = False
With Sheet8
  For i = 1 To InputBox("请输入您需要增加的行数!")
    .Rows("9:9").Copy
    .Range("A10").Insert Shift:=xlDown
Next i
End With
Application.ScreenUpdating = True
Application.DisplayAlerts = False

End Sub
Sub 删除空白行()
Application.DisplayAlerts = False
Application.ScreenUpdating = False
i = Sheet8.Range("a:a").Find("*" & "保管员:" & "*").Row - 6
For j = i To 9 Step -1
    If Len(Sheet8.Cells(j, "d").Value) < 1 Then
        Rows(j & ":" & j).Delete Shift:=xlUp
    End If
Next
Application.DisplayAlerts = ture
Application.ScreenUpdating = True
End Sub

电子台账模板5.rar

48.19 KB, 下载次数: 8

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-5-21 14:53 来自手机 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
Qs18 发表于 2024-5-21 12:13
不知道您要查询数据的条件,还是全部的数据

字段对应收入表字段的内容

TA的精华主题

TA的得分主题

发表于 2024-5-21 15:03 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
Sub 验收记录()
Dim ar As Variant
Dim br()
Dim r As Long
Dim cellDate As Date
Dim i As Long
With Sheets("收入")
    r = .Cells(Rows.Count, 2).End(xlUp).Row
    If r < 2 Then MsgBox "表为空!": End
    ar = .Range("a1:t" & r)
End With
With Sheets("验收记录")
    cellDate = .Range("K3").Value
    If cellDate = 0 Then MsgBox "请输入日期!": End
    ReDim br(1 To UBound(ar), 1 To 12)
    For i = 2 To UBound(ar)
        If ar(i, 20) = cellDate Then
            n = n + 1
            br(n, 1) = n
            br(n, 2) = Split(ar(i, 4), " ", 2)(0) ' 第一个空格前的内容
            br(n, 4) = Split(ar(i, 4), " ", 2)(1) ' 第一个空格后的内容
            br(n, 5) = ar(i, 5)
            br(n, 8) = ar(i, 11)
        End If
    Next i
    If n = "" Then MsgBox "收入表中没有" & cellDate & "的数据!": End
    rs = .Cells(Rows.Count, 1).End(xlUp).Row - 6
    If rs >= 9 Then
        .Rows("9:" & rs).Delete
    End If
     .Rows("9:" & 9 + n - 1).Insert Shift:=xlDown
     For i = 9 To 9 + n - 1
         .Cells(i, 2).Resize(1, 2).Select
         With Selection
             .HorizontalAlignment = xlCenter
             .VerticalAlignment = xlCenter
         End With
         Selection.Merge
         .Cells(i, 8).Resize(1, 2).Select
         With Selection
             .HorizontalAlignment = xlCenter
             .VerticalAlignment = xlCenter
         End With
         Selection.Merge
    Next i
    .[a9].Resize(n, UBound(br, 2)) = br
    .[a8].Resize(n + 1, UBound(br, 2)).Borders.LineStyle = 1
    With .Rows("9:" & n + 9 - 1)
        .Font.Name = "宋体"
        .Font.Size = 11
        .RowHeight = 35
        .WrapText = True
    End With
    '.Cells.EntireRow.AutoFit '自动行高'
End With
MsgBox "ok!"
End Sub

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-17 11:57 , Processed in 0.047881 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表