1234

ExcelHome技术论坛

用户名  找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 请求修改代码:自动编码不重复--密码已解除

[复制链接]

TA的精华主题

TA的得分主题

发表于 2010-11-16 12:50 | 显示全部楼层 |阅读模式
条件:
1. 在A列选择"其它"
2. 在B列选择"对应"的产品类别
3.  在M列自动产生一组合编码,要求所有的编码不重复!
问题:
1. 现在的会重复编!如:M1761自动产生的编码是:3100000001 现改为:3100000002
2. 在M1762在产生时还会是3100000002
请求:
如何让M列代码在已存在的情况下不再产生,接递流水产号呢?

请高人帮修改代码!

[ 本帖最后由 samuel-he 于 2010-11-16 13:42 编辑 ]

test.rar

99.12 KB, 下载次数: 16

TA的精华主题

TA的得分主题

发表于 2010-11-16 13:32 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

回复 1楼 samuel-he 的帖子

要别人帮你。表格中还设置工程保护密码。如何帮你?

TA的精华主题

TA的得分主题

 楼主| 发表于 2010-11-16 13:39 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
原帖由 cm6705 于 2010-11-16 13:32 发表
要别人帮你。表格中还设置工程保护密码。如何帮你?

对不起忘记去掉密码! 一楼已经更新了!

TA的精华主题

TA的得分主题

发表于 2010-11-16 13:42 | 显示全部楼层
我也想知道。

[ 本帖最后由 changxuegu 于 2010-11-16 13:48 编辑 ]

TA的精华主题

TA的得分主题

发表于 2010-11-16 13:56 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

回复 3楼 samuel-he 的帖子

请问G列的数据是自动生成还是输入的?看表格中M列编码前5位是根据E列至G列的数据合并生成的。请详细说明一下。主要是G列的数据生成规则。

TA的精华主题

TA的得分主题

发表于 2010-11-16 14:35 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
由于楼主没有回复我的问题,只能猜测了。见代码:
  1. Private Sub Worksheet_Change(ByVal Target As Range)
  2. Dim Rng As Range, StrHy$
  3.    With Sheets("其它类-11")
  4.       Application.EnableEvents = False
  5.       If Target.Column = 1 Then
  6.          Set Rng = .[a:a].Find(Target.Value, , , 1)
  7.          If Not Rng Is Nothing Then Target(1, 5) = Rng(1, 2)
  8.       ElseIf Target.Column = 2 Then
  9.          Set Rng = .[d:d].Find(Target.Value, , , 1)
  10.          If Not Rng Is Nothing Then Target(1, 5) = Rng(1, 2)
  11.       ElseIf Target.Column = 7 Then
  12.          StrHy = Target(1, -1) & Target(1, 0) & Target
  13.          Cells(Target.Row, "L") = StrHy
  14.          Set Rng = [m:m].Find(StrHy, Lookat:=2, SearchDirection:=2)
  15.          If Not Rng Is Nothing Then
  16.             Cells(Target.Row, "M") = StrHy & Format(Val(Right(Rng, 5)) + 1, "00000")
  17.          Else
  18.             Cells(Target.Row, "M") = StrHy & Format(1, "00000")
  19.          End If
  20.       End If
  21.       Application.EnableEvents = True
  22.    End With
  23. End Sub
复制代码

test.rar

97.19 KB, 下载次数: 21

TA的精华主题

TA的得分主题

 楼主| 发表于 2010-11-16 17:40 | 显示全部楼层
原帖由 cm6705 于 2010-11-16 13:56 发表
请问G列的数据是自动生成还是输入的?看表格中M列编码前5位是根据E列至G列的数据合并生成的。请详细说明一下。主要是G列的数据生成规则。

很抱歉刚离开刚回来!G列是之前的规则现在不管G列.不用自动产生也不用手输

TA的精华主题

TA的得分主题

发表于 2010-11-16 17:57 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
原帖由 samuel-he 于 2010-11-16 17:40 发表

很抱歉刚离开刚回来!G列是之前的规则现在不管G列.不用自动产生也不用手输

还是不太明白,M列的前5位数据是E列至G列的数据生成。即然不管G列数据,那M列数据中的第3至第5位是如何产生的?

TA的精华主题

TA的得分主题

 楼主| 发表于 2010-11-16 20:19 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
原帖由 cm6705 于 2010-11-16 17:57 发表

还是不太明白,M列的前5位数据是E列至G列的数据生成。即然不管G列数据,那M列数据中的第3至第5位是如何产生的?


有答案了!谢谢!
Private Sub Worksheet_Change(ByVal Target As Range)
'用途码
    On Error Resume Next
    If Target.Column = 1 And Target.Count = 1 Then
        Set B = Sheet11.Range("A:A").Find(Target, lookat:=xlWhole)
        If Not B Is Nothing Then
     '  MsgBox Target
            Target.Offset(0, 4) = B.Offset(0, 1)            
        'MsgBox Target
            Target.Offset(0, 4) = e.Offset(0, 1)
            
      
            
                       '编码
w = Target.Row
For K = 5 To 6
Cells(w, 12) = Cells(w, 12) & Cells(w, K)
Next
x = Split(Range("l2:l" & w).Find(what:=Cells(w, 12), after:=Cells(w, 12), lookat:=xlWhole, _
    SearchDirection:=xlPrevious).Offset(, 1), Cells(w, 12))(1)
Cells(w, 13) = Cells(w, 12) * 100000000 + x + 1
End If
            End If            
    End Sub
红色部分为修改的地方.

TA的精华主题

TA的得分主题

发表于 2018-7-12 11:07 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

1234

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

GMT+8, 2025-4-12 09:22 , Processed in 0.041434 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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