ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 某表(2) 数据替换到 某表 能优化下代码吗

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-7-1 11:16 | 显示全部楼层 |阅读模式
image.jpg image.jpg image.png



某表带(2)的数据替换到没带(2)的某表
①所有表的行数不一致 ②某表跟某表(2),列数会一致 【关于行列数不一致我是用选择A1单元格 按CTRL+A 就可以解决这个问题】

目前我弄的哪个代码行数太多了1000来行代码,因为有80多个表,可能就只有里面部分10个表,10个表其中几个带(2)要替换数据,这个能帮我优化下简洁的代码吗?我看内容都是大差不差的,差距就是表名不一致


Sub 数据替换()

    If testFile("柱 (2)") Then
        Sheets("柱").Activate
        Range("A1").CurrentRegion.Select
        Selection.Clear
        Sheets("柱 (2)").Activate
        Range("A1").CurrentRegion.Select
        Selection.Copy
        Sheets("柱").Activate
        Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlPasteSpecialOperationNone, SkipBlanks:=False, Transpose:=False
        Selection.PasteSpecial Paste:=xlPasteFormats, Operation:=xlPasteSpecialOperationNone, SkipBlanks:=False, Transpose:=False
    End If

    If testFile("自定义面 (2)") Then
        Sheets("自定义面").Activate
        Range("A1").CurrentRegion.Select
        Selection.Clear
        Sheets("自定义面 (2)").Activate
        Range("A1").CurrentRegion.Select
        Selection.Copy
        Sheets("自定义面").Activate
        Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlPasteSpecialOperationNone, SkipBlanks:=False, Transpose:=False
        Selection.PasteSpecial Paste:=xlPasteFormats, Operation:=xlPasteSpecialOperationNone, SkipBlanks:=False, Transpose:=False
    End If

    If testFile("自定义贴面 (2)") Then
        Sheets("自定义贴面").Activate
        Range("A1").CurrentRegion.Select
        Selection.Clear
        Sheets("自定义贴面 (2)").Activate
        Range("A1").CurrentRegion.Select
        Selection.Copy
        Sheets("自定义贴面").Activate
        Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlPasteSpecialOperationNone, SkipBlanks:=False, Transpose:=False
        Selection.PasteSpecial Paste:=xlPasteFormats, Operation:=xlPasteSpecialOperationNone, SkipBlanks:=False, Transpose:=False
    End If
End Sub

'判断文件是否存在
Public Function testFile(fn As String)
    Dim flg As Boolean
    flg = False
    For i = 1 To Sheets.Count
        If Sheets(i).Name = fn Then
            flg = True
            Exit For
        End If
    Next
    testFile = flg
End Function


表3.zip

149.46 KB, 下载次数: 9

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-7-1 11:59 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
不太好修改,就算了,勉强用了吧,后面有新表名在,再加上去得了

TA的精华主题

TA的得分主题

发表于 2024-7-1 12:32 | 显示全部楼层
再回首-沉默 发表于 2024-7-1 11:59
不太好修改,就算了,勉强用了吧,后面有新表名在,再加上去得了
  1. Sub 数据替换2()
  2.    
  3.     Dim I As Long
  4.     Dim NewName As String
  5.    
  6.     For I = 1 To ThisWorkbook.Sheets.Count
  7.         ' 按照工作簿中工作表的数量进行循环
  8.         NewName = Sheets(I).Name
  9.         If InStr(Sheets(I).Name, "(2)") > 0 Then
  10.             ' 如果工作表名称中含有“(2)”
  11.             NewName = Trim(Replace(Sheets(I).Name, "(2)", ""))
  12.             If WorksheetExists(NewName) Then
  13.                 ' 如果NewName这个工作表存在
  14.                 Sheets(NewName).Activate
  15.                 Range("A1").CurrentRegion.Select
  16.                 Selection.Clear
  17.                 Sheets(I).Activate
  18.                 Range("A1").CurrentRegion.Select
  19.                 Selection.Copy
  20.                 Sheets(NewName).Activate
  21.                 Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlPasteSpecialOperationNone, SkipBlanks:=False, Transpose:=False
  22.                 Selection.PasteSpecial Paste:=xlPasteFormats, Operation:=xlPasteSpecialOperationNone, SkipBlanks:=False, Transpose:=False
  23.             Else
  24.                 MsgBox "工作簿中不存在名称为  " & NewName & "   的工作表,请检查。"
  25.                 End
  26.             End If
  27.         End If
  28.     Next
  29.     MsgBox "OK!"
  30. End Sub
  31. Function WorksheetExists(sheetName As String, Optional wb As Workbook) As Boolean
  32.     ' 测试工作表是否存在
  33.     Dim sheet As Object
  34.    
  35.     If wb Is Nothing Then Set wb = ThisWorkbook
  36.     On Error Resume Next
  37.     Set sheet = wb.Sheets(sheetName)
  38.     On Error GoTo 0
  39.     WorksheetExists = Not sheet Is Nothing
  40. End Function
复制代码

TA的精华主题

TA的得分主题

发表于 2024-7-1 12:34 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
image.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-7-1 14:44 | 显示全部楼层

image.jpg image.png

大佬,我运行了你发的代码,但是总卡在这里,翻译了你发的代码,看不懂错哪了

TA的精华主题

TA的得分主题

发表于 2024-7-1 15:25 | 显示全部楼层
再回首-沉默 发表于 2024-7-1 14:44
大佬,我运行了你发的代码,但是总卡在这里,翻译了你发的代码,看不懂错哪了

检查运行过程中 NewName  这个变量的值,看看和工作表的名称是否一致。检查一下工作表的名称中有没有空格。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-7-1 15:38 | 显示全部楼层
边缘码农 发表于 2024-7-1 15:25
检查运行过程中 NewName  这个变量的值,看看和工作表的名称是否一致。检查一下工作表的名称中有没有空格 ...

大佬,工作表名称,前后中间有空白格的我都删除了,还是显示的那个,你那边能运行的吗

TA的精华主题

TA的得分主题

发表于 2024-7-1 15:45 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
再回首-沉默 发表于 2024-7-1 15:38
大佬,工作表名称,前后中间有空白格的我都删除了,还是显示的那个,你那边能运行的吗

我这边运行正常。把你现在的附件传上来我看一下。

TA的精华主题

TA的得分主题

发表于 2024-7-1 15:55 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
WorksheetExists这个函数使用了可选参数,可能是它的问题。在这个工程中中断一下,看看返回值是什么。如果一直返回False ,就会这样总是提示找不到。

TA的精华主题

TA的得分主题

发表于 2024-7-1 15:56 | 显示全部楼层
我的环境和你的环境肯定是不一样的。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-17 23:29 , Processed in 0.040935 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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