ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 如何根据条件双击是否增减一个固定模板

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-1-19 11:37 | 显示全部楼层 |阅读模式

想通过VBA功能,实现内嵌一个固定模板。这个模板在表格里是看不到的,只有双击决定是否添加/删除。
需求:①希望通过双击A列为“清单”单元格,提示是否新增一个固定模板,点击是,就可以新增固定模板,固定模板为[5-15行],其中B列固定模板序号为根据清单行的序号,增加后缀.,自动往后生成编号(可以扩展,如1.11/1.12/1.13/……等等)。

②定额行可以快速插入删减行,最好序号后缀.后的序号可以自动更新重新生成,如1.1/1.2/1.3,删除1.2行,则1.3行需要自动改为1.2。
③如果清单下面已经增加了一个固定模板,双击清单,则可以提示是否删除该固定模板。删除范围为该清单下面到下条清单中间所有的行。因为做的过程中可能会存在增减定额行。

只要A列单元格为清单,则可以双击显示确认是否增加/删除固定模板,其他位置则双击无效。


感觉这个功能很实用,但不会做,附件已经上传了,希望得到大家的帮助。
固定模板png.png

固定模板.rar

12.33 KB, 下载次数: 8

TA的精华主题

TA的得分主题

发表于 2024-1-25 02:49 | 显示全部楼层
本帖最后由 boyayes 于 2024-1-25 13:31 编辑

好吧,给你改了一下,不要双击了,改为右键菜单了。

当A列的单元格值为"清单"或"定额"时,会启用自定义的右键菜单。

回复2:固定模板.rar

33.54 KB, 下载次数: 11

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-1-19 13:26 | 显示全部楼层
就是一个非常繁琐的力气活而已,没有什么技术难度,先留个记号吧

TA的精华主题

TA的得分主题

发表于 2024-1-19 13:49 | 显示全部楼层
Private Sub Worksheet_BeforeDoubleClick(ByVal T As Range, Cancel As Boolean)
If T.Row > 4 And T.Column = 1 Then
    If T.Count > 1 Then End
    If InStr(T.Value, "清单") = 0 Then End
    Cancel = True
    If T.Offset(1) = "计价" Then
        w = MsgBox("清单已经存在,是否删除下面的清单?", vbYesNo)
        If w = vbNo Then End
        r = Cells(Rows.Count, 1).End(xlUp).Row
        For i = T.Row + 1 To r
            If InStr(Cells(i, 1), "清单") > 0 Then
                js = i
                Exit For
            End If
        Next i
        If js = "" Then
            js = r
        Else
            js = js - 1
        End If
        Rows(T.Row + 1 & ":" & js).Delete
    Else
        w = MsgBox("是否新增一个固定模板?", vbYesNo)
        If w = vbNo Then End
        Rows("5:15").Select
        Selection.Copy
        Rows(T.Row + 1).Select
        Selection.Insert Shift:=xlDown
        hh = T.Offset(, 1).Value
        For i = T.Row + 2 To T.Row + 11
            m = m + 1
            Cells(i, 2) = hh & "." & m
        Next i
   End If
End If
End Sub

TA的精华主题

TA的得分主题

发表于 2024-1-19 13:50 | 显示全部楼层
序号问题没法解决,仅供参考
固定模板.rar (20.72 KB, 下载次数: 14)

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-1-19 14:32 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
请测试。。。。

固定模板.rar

23.3 KB, 下载次数: 12

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-1-19 15:01 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
半百 发表于 2024-1-19 14:32
请测试。。。。

是希望做成内嵌的固定模板,不要从第1个模板里复制,开始的时候,表里是没有一个模板,清单整理完成,才开始固定模板部分的工作,所以固定模板希望做成内嵌的。
看下能不能在帮忙调整下。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-1-19 15:05 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
3190496160 发表于 2024-1-19 13:50
序号问题没法解决,仅供参考

是内嵌的,4楼的大哥是可以自动变化的,您看下可以参照下调整下不。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-1-19 15:18 | 显示全部楼层
3190496160 发表于 2024-1-19 13:50
序号问题没法解决,仅供参考

我发现是要双击模板里的序号,输入回车键,会自动变过来。但不能直接增加模板直接变化。

TA的精华主题

TA的得分主题

发表于 2024-1-19 15:41 | 显示全部楼层
请查收。

在VBA工程的Sheet1里有代码、
在VBA工程的模块1里有代码、
在VBA工程的ThisWorkbook里有代码.

回复:固定模板.rar

26.87 KB, 下载次数: 14

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-1-19 18:03 | 显示全部楼层
c1988138 发表于 2024-1-19 15:01
是希望做成内嵌的固定模板,不要从第1个模板里复制,开始的时候,表里是没有一个模板,清单整理完成,才 ...

不好意思,我不知道怎么“内嵌”模板,只能将其设置在另一表中(隐藏了),用时直接复制。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-19 01:25 , Processed in 0.054090 second(s), 20 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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