ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] change函数中的target怎么对应到其他sheet的相应位置

[复制链接]

TA的精华主题

TA的得分主题

发表于 2017-11-24 18:33 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
我想用change函数,当选择一片区域后,用其他sheet相应位置的内容覆盖当前target。怎么操作呢?
  1. Private Sub Worksheet_Change(ByVal Target As Range)

  2.     Application.EnableEvents = False
  3.    
  4.     If Target.Count > 1 Then      '如果选择了多个单元格,则报警并清除内容
  5.         Target.Value = Sheet("备份").Target.Value
  6.         MsgBox "请每个单元格单独填写!"
  7.     Else
  8.    
  9.         If Target.Value >= 10 Then
  10.             MsgBox "请填写小于10的数!"
  11.             Target.Value = Sheet("备份").Target.Value
  12.         End If
  13.     End If
  14.    
  15.     Application.EnableEvents = True
  16.    
  17. End Sub
复制代码


test1.rar

13.44 KB, 下载次数: 1

TA的精华主题

TA的得分主题

发表于 2017-11-24 18:43 | 显示全部楼层
SHEETS("表名").CELLS(target.ROW,target.COLUMN)

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-11-24 21:41 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
这是单个单元格可以,但如果是相应的一片区域怎么处理?

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-11-24 21:52 | 显示全部楼层
我按照下面的代码。如果在表格中选中一片区域,输入一个数值然后CTRL+回车,区域中的数值是一样的,都可第一个激活的单元格中的数值一样,这不是我想要的。我想让备份页中的所有对应位置的数值都对应显示出来。
  1. Private Sub Worksheet_Change(ByVal Target As Range)

  2.     Application.EnableEvents = False
  3.    
  4.     If Target.Count > 1 Then      '如果选择了多个单元格,则报警并清除内容
  5.         Target.Value = Sheets("备份").Cells(Target.Row, Target.Column).Value
  6.         MsgBox "请每个单元格单独填写!"
  7.     Else
  8.    
  9.         If Target.Value >= 10 Then
  10.             MsgBox "请填写小于10的数!"
  11.             Target.Value = Sheets("备份").Cells(Target.Row, Target.Column).Value
  12.         End If
  13.     End If
  14.    
  15.     Application.EnableEvents = True
  16.    
  17. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2017-11-24 22:00 | 显示全部楼层
在SelectChange被触发时,Target可能存在三种情况
1、单个单元格,例如,B1
这时候Target就与Range("B1")或者Cells(1,2)等效
2、单一单元格区域,例如:B1:C2
这时候Target就包含了四个单元格,可以使用逐个单元格读取方式读取每个单元格
  1.     Dim rRNG As Range
  2.     For Each rRNG In Target
  3.         Debug.Print rRNG
  4.     Next
复制代码

3、多个单元格区域,例如:B1:C2,D3:E4
这时候,Target就包含了两个区,先把区读出,在区内再逐个单元格读取
  1.     Dim rArea As Range, rRNG As Range
  2.     For Each rArea In Target.Areas
  3.         For Each rRNG In rArea
  4.             Debug.Print rRNG
  5.         Next
  6.     Next
复制代码


评分

1

查看全部评分

TA的精华主题

TA的得分主题

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

本版积分规则

关闭

最新热点上一条 /1 下一条

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

GMT+8, 2024-4-26 17:42 , Processed in 0.045042 second(s), 16 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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