Excel精英培训网

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

[已解决]怎么根据名称变换另一个名称

[复制链接]
发表于 2023-2-4 14:27 | 显示全部楼层 |阅读模式
微信截图_20230204142007.jpg
大神帮忙看下当G列名字有鑫浩宇 或者奥德普 或者西泰或者欧达时候
W列毅昌实排或者毅昌预排  则 自动变为 和昌订单 否则默认不变



最佳答案
2023-2-4 16:22
透明世界1987 发表于 2023-2-4 16:14
感谢大神,为什么他只运行前面12行数据会根据代码运算出结果,13行后就不运算了

Sub demo()
   a = [g1:g9999]
   b = [w1:w9999]
   For i = 2 To UBound(a)
      If InStr("鑫浩宇|奥德普|西泰|欧达", a(i,1)) Then
         b(i,1) = replace(b(i,1),"毅昌实排","和昌订单")
         b(i,1) = replace(b(i,1),"毅昌预排","和昌订单")
      End If
   Next
   [w1].resize(ubound(b)) = b
End Sub
excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2023-2-4 14:40 | 显示全部楼层
Private Sub Worksheet_Change(ByVal Target As Range)

   If Target.Column <> 7 then exit sub
   If InStr("鑫浩宇|奥德普|西泰|欧达", Target) Then
      Target.offset(,16).replace "毅昌实排","和昌订单"
      Target.offset(,16).replace "毅昌预排","和昌订单"
   End If

End Sub

回复

使用道具 举报

 楼主| 发表于 2023-2-4 15:27 | 显示全部楼层
cutecpu 发表于 2023-2-4 14:40
Private Sub Worksheet_Change(ByVal Target As Range)

   If Target.Column  7 then exit sub

感谢大神,不过不对哈  您这个是手工填写G列名字,这一页的所有数据是自动处理自动填写进去的,我需要一段插入进去

点评

原來是這樣~~哈哈  发表于 2023-2-4 15:30
回复

使用道具 举报

发表于 2023-2-4 15:38 | 显示全部楼层
透明世界1987 发表于 2023-2-4 15:27
感谢大神,不过不对哈  您这个是手工填写G列名字,这一页的所有数据是自动处理自动填写进去的,我需要一 ...

Sub demo()
   a = Range([g1], [g1].End(4))
   b = Range([w1], [w1].End(4))
   For i = 2 To UBound(a)
      If InStr("鑫浩宇|奥德普|西泰|欧达", a(i,1)) Then
         b(i,1) = replace(b(i,1),"毅昌实排","和昌订单")
         b(i,1) = replace(b(i,1),"毅昌预排","和昌订单")
      End If
   Next
   [w1].resize(ubound(b)) = b
End Sub


回复

使用道具 举报

 楼主| 发表于 2023-2-4 16:14 | 显示全部楼层
cutecpu 发表于 2023-2-4 15:38
Sub demo()
   a = Range([g1], [g1].End(4))
   b = Range([w1], [w1].End(4))

感谢大神,为什么他只运行前面12行数据会根据代码运算出结果,13行后就不运算了
回复

使用道具 举报

发表于 2023-2-4 16:22 | 显示全部楼层    本楼为最佳答案   
透明世界1987 发表于 2023-2-4 16:14
感谢大神,为什么他只运行前面12行数据会根据代码运算出结果,13行后就不运算了

Sub demo()
   a = [g1:g9999]
   b = [w1:w9999]
   For i = 2 To UBound(a)
      If InStr("鑫浩宇|奥德普|西泰|欧达", a(i,1)) Then
         b(i,1) = replace(b(i,1),"毅昌实排","和昌订单")
         b(i,1) = replace(b(i,1),"毅昌预排","和昌订单")
      End If
   Next
   [w1].resize(ubound(b)) = b
End Sub
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-19 17:07 , Processed in 0.569952 second(s), 14 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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