大学综合测评中,使用VBA代码自动完成EXCEL成绩表

本文分享了一段VBA代码,用于自动处理大学综合测评中的EXCEL成绩表,提高效率。该宏适用于厦门理工学院的原始成绩表,能计算学业基本分和排名,需要对VBA和学生综合测评办法有一定了解。使用者需注意核对和修正程序完成后可能存在的0分项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       更新:2014-04-18       下午

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

前言
  1. 我们在校大学生,每年都会评奖学金。而参考指标就是综合测评成绩。综合测评中,期末成绩又是最主要的部分。
  2. 一般每个大学教务系统都会生成一份原始成绩表,然后一级级下发到学习委员手中。而要计算出同学们的学业基本分,是要做很多EXCEL处理和计算工作的。
  3. 我担任过两年学习委员,这方面比较有经验,所以就写了一个宏,让成绩表的制作工作,基本由计算机程序直接完成。这样能大大提高效率。
  4. 本文主要目的:整理成果,方便日后维护、共享代码;留给我校,以后担任学习委员的学弟学妹,在制作综合测评成绩表时,可以使用我的程序增加效率;

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

代码

       History:    (代码修改历史记录列表)

       1.  Date:2013/10/6

       Modification:部分注释错别字,解释错误的改动

       2.  Date:2013/10/10

       Modification:科目名称超过15个字用8号字体

       3.  Date:2013/10/21

       Modification:运行完后,弹出友情提示窗口

Sub 成绩表()
'Author:代号4101 首次发布:2013/10/6

    Dim 行范围, 列范围, 有效范围, 计数, i, j, title, 总学分, logo, str

    '去掉获得学分为0的行
    i = 4
    While Cells(i, 4) <> ""
        If Cells(i, 4) = 0 Then
            Rows(i).Delete Shift:=xlUp
        Else
            i = i + 1
        End If
    Wend
    行范围 = i + 1 '这里有中间计算过程,算出的是最终确立的,最后条数据的行号
    
    '完成行的确定
    title = Cells(1, 1)
    Rows(2).Delete Shift:=xlUp
    Rows(2).Insert Shift:=xlDown
    Rows("4:5").Insert Shift:=xlDown
    
    '删除第一列与第四列
    Columns(1).Delete Shift:=xlToLeft
    Columns(3).Delete Shift:=xlToLeft
    
    '去掉含不计入综测的科目
    有效范围 = 2 * (i - 3) / 3
    j = 3
    While Cells(3, j) <> ""
        计数 = 0
        For i = 6 To 行范围
            If Len(Cells(i, j)) Then
                计数 = 计数 + 1
            End If
        Next
        '①成绩比例小于2/3 ②形势与政策、专业导论等只分合格与不合格的不计入(该处采用不严密的算法,但出错,即定位的6位同学都没有出现“合格”字眼几乎是不可能事件)
        If (计数 < 有效范围) Then
            Columns(j).Delete Shift:=xlToLeft
        ElseIf (Mid(Cells(6, j), 1, 2) = "合格") Or (Mid(Cells(10, j), 1, 2) = "合格") Or (Mid(Cells(20, j), 1, 2) = "合格") Then
            Columns(j).Delete Shift:=xlToLeft
        ElseIf (Mid(Cells(25, j), 1, 2) = "合格") Or (Mid(Cells(28, j), 1, 2) = "合格") Or (Mid(Cells(30, j), 1, 2) = "合格") Then
            Columns(j).Delete Shift:=xlToLeft
        Else
            j = j + 1
        End If
    Wend
    列范围 = j - 1
    Range(Cells(1, 1), Cells(1, 列范围)).FormulaR1C1 = title '有个标题会没掉的BUG,不知道问题在哪,所以在此处补充回来
    
    '提取出第三行的科目类型、科目名称、学分数据
    Dim 第一个位置, 第二个位置, 长度    '找出斜杆的位置
    For j = 3 To 列范围
        i = 1
        Cells(3, j).Select
        While Mid(ActiveCell, i, 1) <> "/"
            i = i + 1
        Wend
        第一个位置 = i
        i = i + 1
        While Mid(ActiveCell, i, 1) <> "/"
            i = i + 1
        Wend
        第二个位置 = i
        长度 = Len(ActiveCell)
        Cells(2, j) = Mid(ActiveCell, 第一个位置 + 1, 第二个位置 - 第一个位置 - 1)
        Cells(4, j) = Mid(ActiveCell, 第二个位置 + 1, 长度 - 第二个位置)
        Cells(3, j) = Left(ActiveCell, 第一个位置 - 1)
    Next
    
    '下面是列交换,先按科目类别名降序排序,再按学分降序排序,完成列的交换
    Range(Cells(2, 3), Cells(行范围, 列范围)).Select
    ActiveSheet.Sort.SortFields.Clear
    ActiveSheet.Sort.SortFields.Add Key:=Range(Cells(2, 3), Cells(2, 列范围)), _
        SortOn:=xlSortOnValues, Order:=xlDescending, DataOption:=xlSortNormal
    ActiveSheet.Sort.SortFields.Add Key:=Range(Cells(4, 3), Cells(4, 列范围)), _
        SortOn:=xlSortOnValues, Order:=xlDescending, DataOption:=xlSortNormal
    With ActiveSheet.Sort
        .SetRange Range(Cells(2, 3), Cells(行范围, 列范围))
        .Header = xlGuess
        .MatchCase = False
        .Orientation = xlLeftToRight
        .SortMethod = xlPinYin
        .Apply
    End With
    
    '第二行类别名相同合并
    i = 3
    While i <= 列范围
        j = i + 1
        While Cells(2, j) = Cells(2, i)
            Cells(2, j).Clear
            j = j + 1
        Wend
        If j = i + 1 Then
            Cells(2, i).MergeCells = False
        Else
            Range(Cells(2, i), Cells(2, j - 1)).MergeCells = True
        End If
        i = j
    Wend
    
    '所有缺数据的地方用0分填充,考察课文本转为数值成绩
    For i = 6 To 行范围
        For j = 3 To 列范围
            Cells(i, j).Select
            If Len(ActiveCell) = 0 Then
                Cells(i, j) = "0"
            Else
                Select Case ActiveCell
                    Case "优秀"
<think>好的,我现在要解决用户在IAR编译器中遇到的错误:“incomplete type is not allowed”。首先,我需要理解这个错误的含义和常见原因。根据我的知识库,这个错误常发生在代码中使用了未完全定义的类型,比如结构体或联合体声明了但未定义,或者前向声明了某个类型但没有提供完整的定义。 首先,我应该检查用户代码中是否有结构体或联合体的声明但没有定义的情况。比如,如果有一个结构体声明为`struct MyStruct;`,但没有后续的完整定义,那么在需要该结构体大小或成员的地方,编译器就会报这个错误。这时候,需要用户补全结构体的定义,包括成员变量。 其次,检查是否在头文件中只声明了类型而没有包含定义。例如,如果在头文件中使用前向声明,但在使用该类型的源文件中没有包含实际的定义头文件,这也会导致错误。此时,需要确保在使用类型的地方包含了正确的头文件,或者将前向声明替换为完整的定义。 另外,还要考虑typedef的问题。如果用户使用了typedef创建别名,但原始类型未完全定义,同样会引发错误。例如,`typedef struct MyStruct MyType;`之后,如果尝试使用MyType但MyStruct尚未定义,就会出错。需要确保在使用typedef之前,原始类型已经被完整定义。 此外,数组声明中的类型不完整也是一个常见原因。比如声明数组时,如果元素类型未完全定义,编译器无法确定数组的大小,导致错误。需要检查数组声明中的类型是否已经完整定义。 可能还有其他情况,比如在C和C++混合编程时,如果没有正确使用extern "C",或者在头文件中遗漏了必要的包含,也可能导致类型不完整。需要用户检查这些方面。 接下来,我需要将这些可能的原因整理成清晰的解决步骤,并给出具体的代码示例,帮助用户理解如何修改。同时,根据用户提供的引用内容,虽然引用[1]和引用[2]是关于其他错误的,但用户可能希望看到类似的结构,即分点说明解决方案,并引用相关资源。 最后,生成相关问题,帮助用户进一步了解可能相关的编译错误,比如类型未定义、前向声明问题等。这样用户可以有更全面的认识,预防其他类似错误的发生。</think>### IAR编译器错误'incomplete type is not allowed'解决方案 该错误表示代码中使用了**未完全定义的类型**,编译器无法确定其内存布局或成员信息。以下是具体原因及解决方法: #### 1. 结构体/联合体未定义完整 若声明了结构体但未定义成员,在实例化时会报错: ```c struct MyStruct; // 前向声明不完整 struct MyStruct var; // 错误:使用未完成类型 ``` **解决方案**:补全类型定义 ```c struct MyStruct { int id; char name[20]; }; ``` #### 2. 头文件包含缺失 当跨文件使用类型时,需确保定义可见: ```c // file.h struct Data; // 前向声明 // file.c struct Data { // 实际定义 int value; }; ``` **解决方案**:在使用该类型的文件中包含定义头文件 ```c #include "file.c" // 包含实际定义 ``` #### 3. typedef别名问题 使用typedef时原始类型必须完整: ```c typedef struct Node NodeT; // 前向声明 NodeT* ptr; // 允许指针声明 NodeT instance; // 错误:不完整类型 ``` **解决方案**:先完成类型定义再typedef ```c struct Node { int data; struct Node* next; }; typedef struct Node NodeT; ``` #### 4. 数组声明不完整 数组元素类型必须完全定义: ```c struct Element; struct Element arr[10]; // 错误:元素类型未定义 ``` **解决方案**: ```c struct Element { int type; float value; }; struct Element arr[10]; // 合法 ``` #### 调试建议 1. 在IAR工程中搜索错误行号定位问题代码 2. 使用Go to Definition功能追踪类型定义 3. 检查所有头文件包含链 4. 确认没有循环依赖的头文件 编译器需要知道类型的完整信息才能: - 计算sizeof大小 - 分配内存空间 - 访问成员变量 - 进行类型对齐 [^1]: 类似类型转换错误可参考浮点转整型的类型适配问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值