VBA提取字段 200

如图,请问怎么讲上面表格的内容提取出来,变成下面表格的样式。... 如图,请问怎么讲上面表格的内容提取出来,变成下面表格的样式。 展开
 我来答
印半双0ip
高粉答主

2018-04-15 · 关注我不会让你失望
知道大有可为答主
回答量:1.3万
采纳率:86%
帮助的人:2376万
展开全部

因为我本人正在学习VBA ,为了煅炼一下自已,会在网上找些问题然后来练手,针对你的这个问题我的思路如下,供你参考一下。

1,首先将表中第二行,第三行的内容相连起来,然后用Split将他们拆分成数组,

2、新建一个工作表,将分解后的内容赋值到新工作表中,因为表中数值并不是单一对应(有一个对应三个值的情况,例如,23.6BB,第二行只有两个值,但下面相连却要三个数值相加)建议你在原表中最好是做成对应的,像21.5CC 一样,有规则在写代码时就会更容易些),所以将表中重复的23.6BB增加一行,并赋值

3.在新增加的工作表中用字典方法汇总数据,然后赋值。最后形成的图片效果

Sub 提取字段()

Dim ARR, I, cp, cp1, CP2, CP3, ARR1, ARR2, ARR3, arr4, RNG As Range, D As Object

ARR = Sheets(1).[A1].CurrentRegion

For I = 2 To UBound(ARR, 2)

cp = cp & ARR(2, I) & "-"

cp1 = cp1 & ARR(3, I) & "+"

Next

CP2 = Left(cp, Len(cp) - 1)

CP3 = Left(cp1, Len(cp1) - 1)

ARR1 = Split(CP2, "-")

ARR2 = Split(CP3, "+")

For I = 0 To UBound(ARR1)

Sheets(2).Cells(I + 1, 1) = ARR1(I)

Next

Set RNG = Sheets(2).Columns("a:a").Find("23.6BB")

Application.Goto RNG

RNG.Select

Selection.Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove

RNG.Offset(-1, 0).Select

ActiveCell.FormulaR1C1 = "=R[1]C"

For I = 0 To UBound(ARR2)

Sheets(2).Cells(I + 1, 2) = ARR2(I)

Next

arr4 = Sheets(2).[A1].CurrentRegion

Set D = CreateObject("Scripting.Dictionary")

For I = 1 To UBound(arr4)

D(arr4(I, 1)) = D(arr4(I, 1)) + arr4(I, 2)

Next

Sheets(1).[H2].Resize(1, D.Count) = D.KEYS

Sheets(1).[H3].Resize(1, D.Count) = D.ITEMS

End Sub

pieryon
2018-04-13 · 知道合伙人数码行家
pieryon
知道合伙人数码行家
采纳数:14411 获赞数:166867
获取软件设计师高级职称 万达金融最佳创新奖

向TA提问 私信TA
展开全部
发到35,8106736
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Ynzsvt
2018-04-15 · TA获得超过6662个赞
知道大有可为答主
回答量:1.5万
采纳率:40%
帮助的人:2663万
展开全部
逐对分列,对应的字典累加后输出。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
柔软的Bp
科技发烧友

2018-04-14 · 智能家居/数码/手机/智能家电产品都懂点
知道大有可为答主
回答量:3万
采纳率:67%
帮助的人:8909万
展开全部
用FIND+LEFT函数就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式