当前位置: 首页 > 图文教程 > 工具软件 > 办公软件 > Excel:轻松合并成绩表

办公软件
绝秘:在Excel中快速输入数据
Excel中常见问题及解决方法
学习Excel 2000入门操作
Excel定时提醒不误事
在Excel中统计与上报两不误
Excel帮你填写报名信息卡
Excel计算住房贷款和个人储蓄
Excel打印故障问答锦囊
EXCEL小技巧:批量修改数据
用EXCEL轻松的处理学生成绩
共享EXCEL工作簿实现协同录入
用EXCEL轻松的准备考前工作
EXCEL大量数据快速录入技巧
提高EXCEL录入速度十大绝招
Excel中用宏和VBa自动统计成绩
Excel宏的应用-成绩分析处理程序
EXCEL进行学生成绩管理
Excel中三表“嵌套”成一表
excel为学生考试成绩排名
巧用Excel建立数据库大法!

办公软件 中的 Excel:轻松合并成绩表


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-01   浏览: 83 ::
收藏到网摘: n/a

每次考完试,学校的教务部门都要将各班提交的成绩进行汇总和分析。由于各班的成绩表都是单独提交的,如何将所有班级的成绩合并到一张工作表上以便于数据的处理呢?这些操作我们平时都是通过复制粘贴来实现的,如果要合并的班级很多,就显得比较繁琐了,而且容易出错。笔者所在学校也有这样的问题,经过一番研究,我用VBA轻轻松松地实现了这一操作。

  假设我们将所有考生的成绩合并到Sheet1中。在当前的工作表中用“控件工具箱”画一个命令按钮并命名为“合并成绩”(如图所示),双击后在其Click事件中输入下面的代码:

  Private Sub CommandButton1_Click()

  '统计要合并的工作表的数量(循环次数)

  For i = 2 To Sheets.Count

  Worksheets(i).Select

  '选择各工作表中的数据区域并复制

  Worksheets(i).Select

  '选择各工作表中的数据区域并复制

  irow = Worksheets(i).[B65536].End(xlUp).Row

  ActiveSheet.Range('A2:AA' && irow).Select

  Selection.Copy

  '粘贴到第一张工作表中

  Worksheets(1).Select

  mrow = [a65536].End(xlUp).Row + 1

  Range('A' && mrow).Select

  ActiveSheet.Paste

  Next i

  '主体程序执行完毕

  [a1].Select

  CommandButton1.Enabled = False

  countall = '一共合并了' + Str([a65536].End(xlUp).Row - 1) + '个学生的成绩,数据表合并成功!'




  MsgBox countall, vbOKOnly, '提示信息'

  End Sub

  程序中“ActiveSheet.Range('A2:AA' && irow).Select”的功能用于选择每张工作表除了第一行以外的数据区域(第一张工作表除外)。

  小提示:在进行本操作之前,首先要保证每张工作表的字段顺序是一致的,且每张成绩中第一行是表格的标题行。要做到这一点也行容易,可事先将制作好的Excel文件用“共享工作簿”的方法共享给老师们以便于他们录入成绩。