Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 3113|回复: 3

根据名称,依次提取代码,并自动生成序列号

[复制链接]
发表于 2015-8-12 13:47 | 显示全部楼层 |阅读模式
要求达到的效果是: 数据.rar (8.61 KB, 下载次数: 0)
1)输入图片3中名称后,编码按引用源中的数据进行填写,如线位移传感器,则先写一级代码,再写二级代码(见图片1),后二位是依据“已生成数据”工作表的相同名称的序号延续(见图片2),如已出现两次线位移传感器,则再在数据中出现,则后面两位变为03(见图片3)
2)如果完成数据填写后增加一个按钮,则将数据自动移动到“已生成数据”工作表中,而“数据”工作表内的数据清空,“已生成数据”工作表不得删除里面的信息
图1
图2
图3

Snap2.jpg (7.48 KB, 下载次数: 0)




excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2015-8-12 14:27 | 显示全部楼层
  1. Sub Macro1()
  2. On Error Resume Next
  3. Dim arr, brr, crr, cr, d, d2, i&, s%, n&
  4. Set d = CreateObject("scripting.dictionary")
  5. Set d2 = CreateObject("scripting.dictionary")
  6. arr = Sheet1.Range("a1").CurrentRegion
  7. brr = Sheet2.Range("a1").CurrentRegion
  8. crr = Sheet3.Range("a1").CurrentRegion
  9. ReDim cr(1 To UBound(crr) - 1, 1 To 2)
  10. For i = 2 To UBound(arr)
  11.     If arr(i, 2) = "" Then arr(i, 2) = arr(i - 2, 2)
  12.     d(arr(i, 3)) = arr(i, 2) & arr(i, 4)
  13. Next
  14. For i = 2 To UBound(brr)
  15.     d2(brr(i, 1)) = d2(brr(i, 1)) + 1
  16. Next
  17. For i = 2 To UBound(crr)
  18.     If Not d2.exists(crr(i, 1)) Then s = 1 Else s = d2(crr(i, 1)) + 1
  19.     cr(i - 1, 1) = crr(i, 1)
  20.     cr(i - 1, 2) = d(crr(i, 1)) & Format(s, "00")
  21. Next
  22. n = Sheet2.Range("a65536").End(xlUp).Row + 1
  23. Sheet2.Cells(n, 1).Resize(UBound(cr), 2) = cr
  24. Sheet3.Range("a1").CurrentRegion.Offset(1, 0).ClearContents
  25. End Sub
复制代码
回复

使用道具 举报

发表于 2015-8-13 14:45 | 显示全部楼层
回复

使用道具 举报

 楼主| 发表于 2015-8-17 10:38 | 显示全部楼层
楼上的程序有些问题,如果是多个的会出现隔行正常,另一行则不正常,出现一级代码数值。见图片,
QQ图片20150817103221.png

另能否在“数据”工作表也显示编码。
非常感谢。
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-6-26 09:30 , Processed in 0.151373 second(s), 11 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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