Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 1946|回复: 3

[已解决]提取数据

[复制链接]
发表于 2012-8-24 21:49 | 显示全部楼层 |阅读模式
提取数据,谢谢帮忙!!
最佳答案
2012-8-24 22:17
Private Sub CommandButton1_Click()
Dim arr, i%, m%, brr(1 To 1000, 1 To 10)
n = Application.Match("%", Range("b1:b" & Range("b65536").End(3).Row), 0)
arr = Range("b1:b" & Range("b65536").End(3).Row)
For i = 1 To UBound(arr)
If Left(arr(i, 1), 1) = "T" And Len(arr(i, 1)) = 3 Then
m = m + 1: r = 0
End If
If (i > n And Len(arr(i, 1)) > 3) Or (Left(arr(i, 1), 1) = "T" And Len(arr(i, 1)) = 3) Then
r = r + 1
brr(r, m) = arr(i, 1)
End If
Next
Range("e1").Resize(r, m) = brr
End Sub

Book1.rar

67.83 KB, 下载次数: 43

发表于 2012-8-24 22:17 | 显示全部楼层    本楼为最佳答案   
Private Sub CommandButton1_Click()
Dim arr, i%, m%, brr(1 To 1000, 1 To 10)
n = Application.Match("%", Range("b1:b" & Range("b65536").End(3).Row), 0)
arr = Range("b1:b" & Range("b65536").End(3).Row)
For i = 1 To UBound(arr)
If Left(arr(i, 1), 1) = "T" And Len(arr(i, 1)) = 3 Then
m = m + 1: r = 0
End If
If (i > n And Len(arr(i, 1)) > 3) Or (Left(arr(i, 1), 1) = "T" And Len(arr(i, 1)) = 3) Then
r = r + 1
brr(r, m) = arr(i, 1)
End If
Next
Range("e1").Resize(r, m) = brr
End Sub

Book1.rar

16.37 KB, 下载次数: 28

回复

使用道具 举报

发表于 2012-8-24 22:27 | 显示全部楼层
本帖最后由 hrpotter 于 2012-8-24 22:34 编辑

理解错误,想复杂了!
回复

使用道具 举报

发表于 2012-8-25 22:27 | 显示全部楼层
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-5-6 07:07 , Processed in 0.405996 second(s), 10 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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