ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] vba数据导出处理

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-4-3 08:55 | 显示全部楼层 |阅读模式
本帖最后由 yujingc 于 2023-4-3 16:00 编辑

现有一组比较杂乱的数据,我需要将表1数据导出成我所需要的数据
希望能够生成如下
1.根据原始数据表生成,编号后面的数据是原始数据表第二行红色的数据
2.把每一个编号对应的主色/点色/发际线数据导出有些主色/点色长度是多个,希望能够合并单元格
3.根据余发列的数据导出每一长度余发不是0的数据并汇总
https://wwi.lanzoup.com/b018r2quf
密码:9tgk

TA的精华主题

TA的得分主题

发表于 2023-4-3 09:31 | 显示全部楼层
真够乱的~~~~~

TA的精华主题

TA的得分主题

发表于 2023-4-3 10:22 | 显示全部楼层
表1设计没有考虑到后期处理,根本就是一团糟,想用代码来解决,可以解决,但是,非常繁琐

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-3 10:59 | 显示全部楼层

大佬你有啥好的表现形式吗?想要求助一下,我自己换了一些形式感觉都没有这个乱的方便

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-3 11:01 | 显示全部楼层
3190496160 发表于 2023-4-3 10:22
表1设计没有考虑到后期处理,根本就是一团糟,想用代码来解决,可以解决,但是,非常繁琐

大佬你有啥好的表现形式吗?想要求助一下,我自己换了一些形式感觉都没有这个乱的方便

TA的精华主题

TA的得分主题

发表于 2023-4-3 11:06 | 显示全部楼层
确实乱,你最起码得竖着放才好做……

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-3 11:09 | 显示全部楼层
高个子 发表于 2023-4-3 11:06
确实乱,你最起码得竖着放才好做……

之前做过一版竖着的,用起来很不方便,因为这个数据是得我根据总克重计算,竖着做对于这些数据我就看的不是很清楚,很容易算错

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-3 11:10 | 显示全部楼层
Option Explicit

Sub x()
    Dim arr, i, j, k, arr2(1 To 1000, 1 To 3), arr3(1 To 1000, 1 To 2), n2, n3, i3
    '从表1数据汇总arr2
    n2 = 0
    arr = Sheets("PO#230212").UsedRange '表1内容
    For i = 2 To UBound(arr)
        For Each k In Array(6, 8, 10, 12) 'F、H、J、L列
            j = k + 1
            If arr(i, j) = "" Then arr(i, j) = arr(i - 1, j) '处理合并单元格
            If arr(i, k) <> "" Then
                'arr(i,1)、 arr(i,k)、arr(i,j) 一组数据累加到数组arr2中
                n2 = n2 + 1
                arr2(n2, 1) = arr(i, 1)
                arr2(n2, 2) = arr(i, k)
                arr2(n2, 3) = arr(i, j)
            End If
        Next k
    Next i
    '从arr2汇总arr3
    n3 = 0
    For i = 1 To n2
        For i3 = 1 To n3
            If Right(arr3(i3, 1), 4) = Right(arr2(i, 3), 4) Then Exit For
        Next i3
        If i3 > n3 Then
            arr3(i3, 1) = arr2(i, 3)
            n3 = i3
        End If
        arr3(i3, 2) = arr3(i3, 2) + arr2(i, 2)
    Next i
    '把结果arr2、arr3保存到 H 列(最后楼主自己修改为A列)
    Sheets("生成").Activate
    Range("h:j").ClearContents
    Cells(1, "H").Resize(n2, 3) = arr2
    Cells(n2 + 2, "H").Resize(n3, 2) = arr3
End Sub

这是一个大佬帮我写的,能够实现将数据导出,但是很多细节还需要修改

TA的精华主题

TA的得分主题

发表于 2023-4-3 11:34 来自手机 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-3 12:52 来自手机 | 显示全部楼层
zpy2 发表于 2023-4-3 11:34
https://club.excelhome.net/forum.php?mod=viewthread&tid=1654712&mobile&_dsign=848d8297

大佬我修改了一下,之前用这种方式但是在具体应用中会出现很多修改,这种方式就不够直接清楚
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-17 04:27 , Processed in 0.035150 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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