Excel精英培训网

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

[已解决]如何用VBA自动计算填写到红色括号中(含括号) ?

[复制链接]
发表于 2013-1-16 16:35 | 显示全部楼层 |阅读模式
假设 A1 输入这样 3/4" 20R*30P*1500L*10F

最后A1输入完毕按回车得出这样结果 3/4" 20R(440mm)*30P(750mm)*1500L(59.06")*10F(2.54mm)


3/4" 20R(左边20*22)*30P(左边30*25)*1500(左边1500/25.4)*10F(左边10/25.4)

请问版主跟高手要怎么写VBA


最佳答案
2013-1-16 19:22
  1. Private Sub Worksheet_Change(ByVal Target As Range)
  2. Dim arr, i As Integer
  3. If Len(Target) - Len(Replace(Target, "*", "")) = 3 Then
  4.     arr = Split(Target, "*")
  5.     arr(0) = arr(0) & "(" & Val(Split(arr(0), " ")(1)) * 22 & "mm)"
  6.     arr(1) = arr(1) & "(" & Val(arr(1)) * 25 & "mm)"
  7.     arr(2) = arr(2) & "(" & Format(Val(arr(2)) / 25.4, "00.00") & """)"
  8.     arr(3) = arr(3) & "(" & 25.4 / Val(arr(3)) & "mm)"
  9.     Application.EnableEvents = False
  10.         Target = Join(arr, "*")
  11.     Application.EnableEvents = True
  12. End If
  13. End Sub
复制代码
发表于 2013-1-16 19:22 | 显示全部楼层    本楼为最佳答案   
  1. Private Sub Worksheet_Change(ByVal Target As Range)
  2. Dim arr, i As Integer
  3. If Len(Target) - Len(Replace(Target, "*", "")) = 3 Then
  4.     arr = Split(Target, "*")
  5.     arr(0) = arr(0) & "(" & Val(Split(arr(0), " ")(1)) * 22 & "mm)"
  6.     arr(1) = arr(1) & "(" & Val(arr(1)) * 25 & "mm)"
  7.     arr(2) = arr(2) & "(" & Format(Val(arr(2)) / 25.4, "00.00") & """)"
  8.     arr(3) = arr(3) & "(" & 25.4 / Val(arr(3)) & "mm)"
  9.     Application.EnableEvents = False
  10.         Target = Join(arr, "*")
  11.     Application.EnableEvents = True
  12. End If
  13. End Sub
复制代码

评分

参与人数 1 +1 收起 理由
lewis16888 + 1 赞一个!

查看全部评分

回复

使用道具 举报

 楼主| 发表于 2013-1-17 07:56 | 显示全部楼层
本帖最后由 lewis16888 于 2013-1-17 08:00 编辑

太牛了,谢谢版主哥哥
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-17 02:06 , Processed in 0.230429 second(s), 14 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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