ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

   
EH云课堂-专业的职场技能充电站 限时送,魔方网表将Excel变在线系统 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
Excel不给力? 何不试试FoxTable! Excel 2016函数公式学习大典 高效办公必会的Office实战技巧 免费下载Excel行业应用视频
300集Office 2010微视频教程 Tableau-数据可视化工具 ExcelHome出品 - VBA代码宝免费下载 13门Excel免费公开课任你学
你的Excel 2010实战技巧学习锦囊 欲罢不能, 过目难忘的 Office 新界面 免费的Excel考勤计算系统
查看: 231|回复: 4

[求助] 数据的合并与提取

[复制链接]

TA的精华主题

TA的得分主题

发表于 2019-1-12 20:22 | 显示全部楼层 |阅读模式
将偶数行的数值与奇数行的数值进行合并,将合并的结果记录在奇数行,然后将奇数行的指定列复制到其他工作表,具体如下如下:
1:工作表Template每个偶数行和奇数行为一组数据,将偶数行和奇数行中同为不是0的数字的单元格的数字进行合并中间用"\"隔开,合并后的数值放在对应的奇数行单元格中;
2:将工作表Template中奇数行的数据按工作表OriginalData中字段要求和排列复制到工作表OriginalData中;
3:工作表OriginalData中的字段可根据需要,从工作表Template中已有的字段中添加;
4:数据量非常庞大,寻求一个较为快带的解决方法;
谢谢!

Sample.zip

547.42 KB, 下载次数: 7

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-1-12 20:28 | 显示全部楼层
两个工作表中的字段的排序可能不一样!

TA的精华主题

TA的得分主题

发表于 2019-1-12 22:34 | 显示全部楼层
看看是不是你想要的
  1. Sub test()
  2.     arr = Sheet4.[a1].CurrentRegion
  3.     brr = Sheet1.[a4].CurrentRegion
  4.     Set columnN = CreateObject("scripting.dictionary")
  5.     Dim crr
  6.     For i = 1 To UBound(brr, 2)
  7.         For j = 1 To UBound(arr, 2)
  8.             If arr(1, j) = brr(1, i) Then columnN(brr(1, i)) = j
  9.         Next
  10.     Next
  11.     For i = 2 To UBound(arr) Step 2
  12.         For j = 1 To UBound(arr, 2)
  13.             If arr(i, j) <> "" And arr(i, j) <> 0 And arr(i + 1, j) <> "" And arr(i + 1, j) <> 0 Then arr(i + 1, j) = arr(i, j) & "" & arr(i + 1, j)
  14.         Next
  15.     Next
  16.     Sheet4.[a1].CurrentRegion = arr
  17.     ReDim crr(1 To UBound(arr), 1 To UBound(brr, 2))
  18.     Z = 1
  19.     For i = 3 To UBound(arr) Step 2
  20.         For j = 1 To UBound(brr, 2)
  21.             If columnN.exists(brr(1, j)) Then crr(Z, j) = arr(i, columnN(brr(1, j)))
  22.         Next
  23.         Z = Z + 1
  24.     Next
  25.     Sheet1.[a5].Resize(UBound(arr), UBound(brr, 2)) = crr
  26. End Sub
复制代码


Sample(测试).rar

537.4 KB, 下载次数: 5

评分

参与人数 1鲜花 +1 收起 理由
xgluo + 1 感谢帮助

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-1-13 09:48 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-1-13 18:33 | 显示全部楼层
yayahzmeng 发表于 2019-1-12 22:34
看看是不是你想要的

Yayahzmeng ,是否可能不在工作表Template中进行偶、奇数行的数字合并?直接将合并的结果与奇数行的其他所需的数据写入工作表OriginalData中,这样可保持Template中的数据的原始状态。谢谢!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

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

关注官方微信,每天学会一个新技能

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

GMT+8, 2019-1-24 20:32 , Processed in 0.097858 second(s), 17 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 2001-2017 Wooffice Inc.

   

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

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

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