ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 请大佬帮忙根据总表生成分析表

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-5-7 15:02 | 显示全部楼层 |阅读模式
请大佬帮忙根据总表自动生成分析表

三率分析.zip

21.25 KB, 下载次数: 8

TA的精华主题

TA的得分主题

发表于 2024-5-7 16:10 | 显示全部楼层
  1. Sub test()
  2.     Dim r%, i%
  3.     Dim arr, brr
  4.     Dim d As Object
  5.     Application.ScreenUpdating = False
  6.     Application.DisplayAlerts = False
  7.     Set d = CreateObject("scripting.dictionary")
  8.     Set d1 = CreateObject("scripting.dictionary")
  9.     With Worksheets("总表")
  10.         r = .Cells(.Rows.Count, 1).End(xlUp).Row
  11.         c = .Cells(1, .Columns.Count).End(xlToLeft).Column
  12.         arr = .Range("a1").Resize(r, c)
  13.     End With
  14.     For j = 3 To UBound(arr, 2) Step 7
  15.         ReDim brr(1 To UBound(arr) - 2, 1 To 10)
  16.         For i = 3 To UBound(arr)
  17.             brr(i - 2, 1) = arr(i, 1)
  18.             brr(i - 2, 2) = arr(i, 2)
  19.             brr(i - 2, 3) = arr(i, j + 6)
  20.             brr(i - 2, 5) = arr(i, j + 1)
  21.             brr(i - 2, 7) = arr(i, j + 3)
  22.             brr(i - 2, 9) = arr(i, j + 5)
  23.         Next
  24.         For Each q In Array(3, 5, 7, 9)
  25.             d1.RemoveAll
  26.             For i = 1 To UBound(brr)
  27.                 If Len(brr(i, q)) <> 0 Then
  28.                     d1(brr(i, q)) = d1(brr(i, q)) + 1
  29.                 End If
  30.             Next
  31.             nn = 1
  32.             kk = d1.keys
  33.             For k = 0 To UBound(kk)
  34.                 mm = Application.Large(kk, k + 1)
  35.                 ss = d1(mm)
  36.                 d1(mm) = nn
  37.                 nn = nn + ss
  38.             Next
  39.             For i = 1 To UBound(brr)
  40.                 If Len(brr(i, q)) <> 0 Then
  41.                     brr(i, q + 1) = d1(brr(i, q))
  42.                 End If
  43.             Next
  44.         Next
  45.         
  46.         d(arr(1, j)) = brr
  47.     Next
  48.     With Worksheets("分析表")
  49.         .Cells.Clear
  50.         .Range("e:e,g:g,i:i").NumberFormatLocal = "0.00%"
  51.         r = 1
  52.         s = 0
  53.         For Each aa In d.keys
  54.             s = s + 1
  55.             brr = d(aa)
  56.             With .Cells(r, 1)
  57.                 .Value = aa
  58.                 .Resize(1, 10).Merge
  59.             End With
  60.             With .Cells(r + 1, 1).Resize(1, 10)
  61.                 .Value = Array("初一年级", "统计人数", "平均分", "名次", "优秀率", "名次", "良好率", "名次", "合格率", "名次")
  62.             End With
  63.             With .Cells(r + 2, 1).Resize(UBound(brr), UBound(brr, 2))
  64.                 .Value = brr
  65.             End With
  66.             With .Cells(r, 1).Resize(2 + UBound(brr), UBound(brr, 2))
  67.                 .Borders.LineStyle = xlContinuous
  68.                 .BorderAround LineStyle:=xlContinuous, Weight:=xlMedium
  69.                 If s Mod 2 = 0 Then
  70.                     .Interior.Color = 15132391
  71.                 End If
  72.             End With
  73.             r = r + 2 + UBound(brr)
  74.         Next
  75.         With .Range("a1:j" & r - 1)
  76.             With .Font
  77.                 .Name = "微软雅黑"
  78.                 .Size = 12
  79.             End With
  80.         End With
  81.         .Rows(1).Resize(r - 1).RowHeight = 18
  82.         With .UsedRange
  83.             .HorizontalAlignment = xlCenter
  84.             .VerticalAlignment = xlCenter
  85.         End With
  86.     End With
  87. End Sub
复制代码

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-5-7 16:12 | 显示全部楼层
练练手。。

三率分析.rar

49.12 KB, 下载次数: 13

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-5-7 16:23 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-5-11 17:00 | 显示全部楼层
弄起来还有点麻烦,是这个效果吗?
录制_2024_05_11_16_58_54_265.gif

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-5-11 17:01 | 显示全部楼层
JSA代码,共参考
  1. function 数据整理(){
  2.         let arr=Sheets.Item("总表").Range("a1").CurrentRegion.Value2;
  3.         let bt1=arr[0],bt2=arr[1];
  4.         let cls=arr.slice(2,arr.length-1).map(x=>[x[0]]);                //获取班级
  5.         let mbarr=[[null],["初一年级","统计人数","平均分","名次","优秀率","名次","良好率","名次","及格率","名次"]].concat(cls);
  6.         let obj=bt1.reduce((dic,y,j)=>{
  7.                 if (j<=1) return dic;
  8.                 if (mbarr[1].indexOf(bt2[j])==-1) return dic;                //找不到要匹配的项目
  9.                 let temp=dic[y]=dic[y] || JSON.parse(JSON.stringify(mbarr));
  10.                 let n=temp[1].indexOf(bt2[j]);
  11.                 temp[0][0]=y;                //科目
  12.                 arr.slice(2,arr.length-1).forEach(x=>{
  13.                         let m=temp.findIndex(z=>z[0]==x[0]);
  14.                         let tp=temp[m];
  15.                         tp[1]=x[1],tp[n]=x[j];
  16.                         let k=3+mbarr.length*(Object.keys(dic).length-1);
  17.                         let l=mbarr.length*Object.keys(dic).length;
  18.                         tp[n+1]=`=RANK.EQ(RC[-1],R${k}C[-1]:R${l}C[-1],)`;
  19.                 });
  20.                 return dic;
  21.         },{});
  22.         let res=Object.values(obj).flat();
  23.         Sheets.Item("分析表").Activate();
  24.         Cells.Delete();
  25.         Range("a1").Resize(res.length,res[1].length).FormulaR1C1=res;
  26.         //设置格式
  27.         Range("a1").CurrentRegion.Borders.LineStyle=xlContinuous;
  28.         Range("a1").CurrentRegion.HorizontalAlignment=xlHAlignCenter;
  29.         res[1].forEach((x,i)=>x.includes("率")?Cells.Item(1,i+1).EntireColumn.NumberFormatLocal="0.0%":null);
  30.         res.forEach((x,i)=>x[1]==null?Range(`a${i+1}`).Resize(1,10).Merge():null);
  31. }
复制代码

TA的精华主题

TA的得分主题

发表于 2024-5-11 17:02 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
附件,WPS测试,谢谢

三率分析.zip

42.52 KB, 下载次数: 6

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-5-14 14:53 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-5-14 14:56 | 显示全部楼层
Sub test()
Dim wsS As Worksheet, wsA As Worksheet
    Dim sHr As Long, aHr As Long
    Dim hRg As Range, sC As Range
    Dim cR(), i%, pC%, fF As Boolean
    Set wsS = ThisWorkbook.Worksheets("总表")
    Set wsA = ThisWorkbook.Worksheets("分析表 (2)")
    sHr = 2: aHr = 2
    With wsA
        Set hRg = .Range(.Cells(aHr, 1), .Cells(aHr, .Columns.Count).End(xlToLeft))
       Set Rng = .Range(.Cells(2, 1), .Cells(2, .Columns.Count).End(xlToRight))
        dr = Rng.Value
    End With
    ' 动态创建数组
    ReDim cR(1 To hRg.Cells.Count)
    pC = 0 ' 初始化前一列位置
    For Each cell In hRg
        Set sC = wsS.Rows(sHr).Find(What:=cell.Value, LookIn:=xlValues, LookAt:=xlWhole)
        If Not sC Is Nothing Then
            cR(i + 1) = sC.Column
            pC = sC.Column ' 更新前一找到的列位置
            fF = True ' 标记已找到
        ElseIf fF Then ' 使用前一列位置
            cR(i) = pC
        End If
        i = i + 1
        fF = False ' 重置找到标记
    Next cell
Set sht = Sheets("总表")
    ar = sht.Range("a1").CurrentRegion
    m = UBound(ar) - 3
With Sheets("分析表")
    .UsedRange.Clear
    c = 1
    k = 0
    For j = 1 To UBound(ar, 2) ' 遍历第一行的所有列
        If InStr(1, ar(1, j), "总分", vbTextCompare) > 0 Then ' 检查是否包含“总分”
            k = k + 1
        End If
    Next j
    For j = 0 To UBound(ar, 2) - 3 Step k
        .Cells(c, 1) = ar(1, j + 3)
        .Cells(c, 1).Resize(1, UBound(cR)).Merge
        .Cells(c + 1, 1).Resize(1, UBound(cR)) = dr
        sD = c: c = c + 1
        For i = 3 To UBound(ar) - 1
            c = c + 1
             For Z = 1 To UBound(cR)
                 If Z > 2 And Z Mod 2 = 0 Then
                    .Cells(c, Z) = Application.Rank(ar(i, j + cR(Z - 1)), sht.Cells(3, j + cR(Z - 1)).Resize(m))
                    Else
                    .Cells(c, Z) = ar(i, cR(Z))
                End If
            Next
        Next
        c = c + 1
    Next
    With .Range("a1").CurrentRegion
        .Borders.LineStyle = 1
        .HorizontalAlignment = xlCenter
        .VerticalAlignment = xlCenter
        .Font.Size = 14
    End With
    For Each col In .Range("2:2").Columns ' 假设表头在第二行
        ' 获取表头单元格的值
        Set headerCell = col.Cells(1)
        headerText = headerCell.Value
        ' 检查表头是否包含"率"字,并设置百分比格式
        If InStr(1, headerText, "率", vbTextCompare) > 0 Then
            headerCell.EntireColumn.NumberFormat = "0.00%"
        End If
    Next col
End With
End Sub
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-21 20:00 , Processed in 0.045732 second(s), 18 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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