ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 求按比例随机抽取数据方法

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-9-24 20:45 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
麻烦各位。


要求:
1、随机抽取B列“题库名称”为:“A”的整行数据到分表;要求抽取 20题;
2、抽取比例要求:单选(A列) 60%,多选40%;
3、速度尽量快些;

感谢.




随机抽取.zip (16.74 KB, 下载次数: 57)

TA的精华主题

TA的得分主题

发表于 2018-9-24 21:11 | 显示全部楼层
楼主是搞通信的啊
可以考虑使用字典进行去重处理的

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-9-24 21:25 | 显示全部楼层
liulang0808 发表于 2018-9-24 21:11
楼主是搞通信的啊
可以考虑使用字典进行去重处理的

正是搞通信的哈,哈哈;

主要是随机提取,我就不会了。

TA的精华主题

TA的得分主题

发表于 2018-9-24 21:39 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
用字典分别记录单选和多选的题号,再随机抽取。
其实,不用字典也可以

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-9-24 21:56 | 显示全部楼层
小花鹿 发表于 2018-9-24 21:39
用字典分别记录单选和多选的题号,再随机抽取。
其实,不用字典也可以

帮写下呢,可以不,谢谢

TA的精华主题

TA的得分主题

发表于 2018-9-24 23:00 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-9-24 23:04 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-9-24 23:46 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
  1. Sub t()
  2. Dim arr(1 To 26, 1 To 16), brr(1 To 23, 1 To 16), i%, x%, y%, d, k
  3. Set d = CreateObject("Scripting.Dictionary")
  4.   x = 1: y = 1
  5. For i = 2 To [a65536].End(3).Row

  6. If Range("b" & i) = "A" Then
  7.     If Range("a" & i) = "多选" Then
  8.        arr(x, 1) = Range("a" & i)
  9.        arr(x, 2) = Range("b" & i)
  10.        arr(x, 3) = Range("c" & i)
  11.        arr(x, 4) = Range("d" & i)
  12.        arr(x, 5) = Range("e" & i)
  13.        arr(x, 6) = Range("f" & i)
  14.        arr(x, 7) = Range("g" & i)
  15.        arr(x, 8) = Range("h" & i)
  16.        arr(x, 9) = Range("i" & i)
  17.        arr(x, 10) = Range("j" & i)
  18.        arr(x, 11) = Range("k" & i)
  19.        arr(x, 12) = Range("l" & i)
  20.        arr(x, 13) = Range("m" & i)
  21.        arr(x, 14) = Range("o" & i)
  22.        arr(x, 15) = Range("p" & i)
  23.        arr(x, 16) = Range("q" & i)
  24.            x = x + 1
  25.      Else
  26.        brr(y, 1) = Range("a" & i)
  27.        brr(y, 2) = Range("b" & i)
  28.        brr(y, 3) = Range("c" & i)
  29.        brr(y, 4) = Range("d" & i)
  30.        brr(y, 5) = Range("e" & i)
  31.        brr(y, 6) = Range("f" & i)
  32.        brr(y, 7) = Range("g" & i)
  33.        brr(y, 8) = Range("h" & i)
  34.        brr(y, 9) = Range("i" & i)
  35.        brr(y, 10) = Range("j" & i)
  36.        brr(y, 11) = Range("k" & i)
  37.        brr(y, 12) = Range("l" & i)
  38.        brr(y, 13) = Range("m" & i)
  39.        brr(y, 14) = Range("o" & i)
  40.    
  41.            y = y + 1
  42.       End If
  43.    End If
  44.    Next
  45.    Stop
  46.    For i = 1 To 26
  47.     d(WorksheetFunction.RandBetween(1, 26)) = ""
  48.    Next
  49.    s = d.keys
  50.   Stop
  51.      Sheet2.Select
  52.   For i = 2 To 13
  53.       Sheet2.Range("a" & i) = arr(s(i - 2), 1)
  54.       Sheet2.Range("b" & i) = arr(s(i - 2), 2)
  55.       Sheet2.Range("c" & i) = arr(s(i - 2), 3)
  56.       Sheet2.Range("d" & i) = arr(s(i - 2), 4)
  57.       Sheet2.Range("e" & i) = arr(s(i - 2), 5)
  58.       Sheet2.Range("f" & i) = arr(s(i - 2), 6)
  59.       Sheet2.Range("g" & i) = arr(s(i - 2), 7)
  60.       Sheet2.Range("h" & i) = arr(s(i - 2), 8)
  61.       Sheet2.Range("i" & i) = arr(s(i - 2), 9)
  62.       Sheet2.Range("j" & i) = arr(s(i - 2), 10)
  63.       Sheet2.Range("k" & i) = arr(s(i - 2), 11)
  64.       Sheet2.Range("l" & i) = arr(s(i - 2), 12)
  65.       Sheet2.Range("m" & i) = arr(s(i - 2), 13)
  66.       Sheet2.Range("n" & i) = arr(s(i - 2), 14)
  67.       Sheet2.Range("o" & i) = arr(s(i - 2), 15)
  68.       Sheet2.Range("p" & i) = arr(s(i - 2), 16)
  69.        Next
  70.        Stop
  71.    d.RemoveAll
  72.   For i = 1 To 23
  73.     d(WorksheetFunction.RandBetween(1, 23)) = ""
  74.    Next
  75.    s = d.keys
  76.   For i = 14 To 21
  77.       Sheet2.Range("a" & i) = brr(s(i - 14), 1)
  78.       Sheet2.Range("b" & i) = brr(s(i - 14), 2)
  79.       Sheet2.Range("c" & i) = brr(s(i - 14), 3)
  80.       Sheet2.Range("d" & i) = brr(s(i - 14), 4)
  81.       Sheet2.Range("e" & i) = brr(s(i - 14), 5)
  82.       Sheet2.Range("f" & i) = brr(s(i - 14), 6)
  83.       Sheet2.Range("g" & i) = brr(s(i - 14), 7)
  84.       Sheet2.Range("h" & i) = brr(s(i - 14), 8)
  85.       Sheet2.Range("i" & i) = brr(s(i - 14), 9)
  86.       Sheet2.Range("j" & i) = brr(s(i - 14), 10)
  87.       Sheet2.Range("k" & i) = brr(s(i - 14), 11)
  88.       Sheet2.Range("l" & i) = brr(s(i - 14), 12)
  89.       Sheet2.Range("m" & i) = brr(s(i - 14), 13)
  90.       Sheet2.Range("n" & i) = brr(s(i - 14), 14)
  91.       Sheet2.Range("o" & i) = brr(s(i - 14), 15)
  92.       Sheet2.Range("p" & i) = brr(s(i - 14), 16)
  93.        Next
  94. End Sub
复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2018-9-25 07:35 | 显示全部楼层
  1. Sub aaa()
  2.     t = 20
  3.     Dim rng As Range
  4.     Set d1 = CreateObject("scripting.dictionary")
  5.     Set d2 = CreateObject("scripting.dictionary")
  6.     Application.ScreenUpdating = False
  7.     Sheets("分表").UsedRange.Offset(1).ClearContents
  8.     arr = Sheets("总表").UsedRange
  9.     With Sheets("总表")
  10.         For j = 2 To UBound(arr)
  11.             If arr(j, 1) = "多选" Then
  12.                 d1(j) = j
  13.             Else
  14.                 If arr(j, 1) = "单选" Then
  15.                     d2(j) = j
  16.                 End If
  17.             End If
  18.         Next j
  19.         Set rng = Nothing
  20.         For j = 1 To t * 0.6
  21.             x = d2.keys()(WorksheetFunction.RandBetween(0, d2.Count - 1))
  22.             If rng Is Nothing Then
  23.                 Set rng = .Cells(x, 1)
  24.             Else
  25.                 Set rng = Union(rng, .Cells(x, 1))
  26.             End If
  27.             d2.Remove x
  28.         Next j
  29.         rng.EntireRow.Copy Sheets("分表").Cells(Rows.Count, 1).End(3).Offset(1)
  30.         Set rng = Nothing
  31.         For j = 1 To t * 0.4
  32.             x = d1.keys()(WorksheetFunction.RandBetween(0, d1.Count - 1))
  33.             If rng Is Nothing Then
  34.                 Set rng = .Cells(x, 1)
  35.             Else
  36.                 Set rng = Union(rng, .Cells(x, 1))
  37.             End If
  38.             d1.Remove x
  39.         Next j
  40.         rng.EntireRow.Copy Sheets("分表").Cells(Rows.Count, 1).End(3).Offset(1)
  41.     End With

  42.     Application.ScreenUpdating = True
  43. End Sub
复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2018-9-25 07:36 | 显示全部楼层
楼主这是要参加什么竞赛吗?
不过感觉楼主题库的答案看着有些别扭呢

随机抽取.zip

28.03 KB, 下载次数: 44

评分

1

查看全部评分

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

本版积分规则

关闭

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

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

GMT+8, 2024-4-19 07:16 , Processed in 0.039602 second(s), 18 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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