《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于Visual Basic的教師課表自動匯總系統開發
基于Visual Basic的教師課表自動匯總系統開發
來源:微型機與應用2012年第13期
劉信香
(中原工學院 圖書館,河南 鄭州 450007)
摘要: 根據實際工作的需要,開發了一套基于Visual Basic程序的教師課表自動匯總系統。該系統可自動讀取課表數據,并將讀取的數據匯總后自動生成總課表文件,可代替人工的繁瑣重復勞動,具有效率高、方便快捷的特點。
Abstract:
Key words :

摘  要: 根據實際工作的需要,開發了一套基于Visual Basic程序的教師課表自動匯總系統。該系統可自動讀取課表數據,并將讀取的數據匯總后自動生成總課表文件,可代替人工的繁瑣重復勞動,具有效率高、方便快捷的特點。
關鍵詞: 高校;課表;Visual Basic;EXCEL

 在高校,因為工作需要,二級院系每到學期的開學初,都需要制作一份本院系所有任課教師上課安排的總課表。每位教師的課表可從學校的教務系統中自動導出,但不少高校,總課表往往卻不能從系統中自動生成,而需要教學秘書手工完成。雖然總課表也是一張課表,但它是將所有課表進行匯總而成,要靠手工來完成課表的匯總工作,需要將本院系所有任課教師的課表都打印出來,一邊在計算機上復制、粘貼,一邊進行核對,以免出現遺漏或重復。這樣不僅需要耗費大量的紙張,而且工作量大、效率低,一張總課表往往需要一周的時間才能制作完成,同時匯總的課表差錯多,給實際使用時帶來很多問題。本文根據實際工作的需要,結合課表的特點,利用Visual Basic6.0開發了一套教師課表自動匯總系統[1-2]。
1 自動匯總系統總體設計
1.1 課表結構分析

 本文以中原工學院使用過的清華紫光教務系統為例進行說明。在系統設計之前,首先要分析課表的結構。由教務系統導出的教師個人課表是EXCEL文件,圖1是從課表中截取的某一節課的安排示意圖。從圖1中可以看出,對每一節課的安排需占用EXCEL表中8行表格,第一行表示的是該課程的名稱和課程號,后面依次是上課地點、上課周次和上課班級等信息。在VB程序讀取課程安排時,每節課都需要連續讀取8行的數據,然后將讀出的這8行數據連接起來,就構成了一節課的完整安排,經適當整理后輸出到總課表中。

1.2 程序設計思路
 先為總課表建立一個二維數組來保存相關數據,數組的每個成員都代表總課表中的某一節課。在將每張課表中的每節課安排讀取后都匯總到對應的數組成員中。這樣,在將所有課表讀完后,總課表的數據匯總工作也就完成了。然后,先根據所需要的總課表格式生成一張空白總課表,再將二維數組中的數據放入相應的表格內,一張總課表就制作出來了。
1.3 程序設計流程
 課表匯總系統的設計,首先要讀出教師名稱和人數,人數是作為后面讀取課表時判斷是否將所有課表讀完的依據。然后是順序讀每張課表,讀取課表時從周一讀到周六,每個工作日的數據是從第1大節讀到第6大節。將所有課表讀完后,再將匯總到二維數組的數據放入總課表中對應的表格內,最后保存總課表。圖2是程序設計流程框圖。

2 軟件主要功能模塊的實現
2.1 VB與EXCEL數據的鏈接

 VB(Visual Basic)是一種應用十分廣泛的程序開發工具,具有可視化、事件驅動編程的特點,它在界面設計、繪圖、制表、運算、通信和多媒體開發方面都具有簡單易行、功能強大等優點。VB具有強大的數據處理功能,提供了多種數據訪問方法,可以將EXCEL數據表視為一個數據庫,方便地進行訪問和處理[3]。
本系統利用面向對象的ADO技術實現對數據庫(即EXCEL表)的訪問。ADO(ActiveX Data Object)是ActiveX數據對象,是Microsoft公司開發數據庫應用程序面向對象的新接口。VB利用ADO的Connection和Recordset對象可以直接訪問數據,也就是ADO從一個數據源中獲得記錄只需一個連接和一個記錄集[4]。其過程如下:
 (1)在工程中引用“Microsoft Excel 11.0 Object Library”,然后在窗體的通用聲明部分分別定義一個Connection對象和RecordSet對象:
Dim cn As ADODB.Connection
Dim rs As ADODB.Recordset
?。?)在程序中設計一個EXCEL表讀取模塊,新建一個Connection對象的實例并將它賦給cn數據源,新建一個Recordset對象的實例并使用Recordset對象的Open方法打開課表。
Set cn=New ADODB.Connection
Set rs=1New ADODB.Recordset

With cn
    .Provider = "Microsoft.Jet.OLEDB.4.0"
    .ConnectionString="Data source=" & address_file & ";Extended Properties=′Excel 8.0;HDR=No;IMEX=1′"                      //address_file: EXCEL文件位置
    .CursorLocation = adUseClient
    .Open
End With
這樣Visual Basic程序就與EXCEL表之間建立了聯系,也就可以對表中的數據進行處理了。
2.2 課表數據的讀取
 程序在與EXCEL表建立鏈接之后,即開始對課表中的數據進行讀取。先定義一個二維數組來保存每節課的安排,每張課表同一時間的課程安排在被讀出后都追加到同一個二維數組成員中。其過程如下:
Public course_each(5, 6) As String                    //定義二維數組,課程(節,星期)
Dim kecheng As String                              //保存讀取的某節課中的數據
Dim week_course As String                   //星期幾
Dim counter_row As Integer                          
//當前所讀取的某節課單元格行數
讀EXCEL表中的數據
For j = 1 To 6                 //讀一周中的某天
   rs.MoveFirst
    
   Select Case j    //選擇星期幾
      Case 1
         week_course="星期一"
      Case 2
         week_course="星期二"
      Case 3
         week_course="星期三"
      Case 4
         week_course="星期四"
      Case 5
         week_course="星期五"
      Case Else
         week_course="星期六"
   End Select
    
   For i=1 To 5            //讀一天中的5節課
        counter_row=0                         
        kecheng=""   //讀取并保存一節課中的數據
       Do While counter_row<8                 
//讀取每節課占的8個單元格
          counter_row=counter_row+1
          If kecheng="" Then
             kecheng=kecheng & rs.Fields
(week_course).Value
          Else
             kecheng=kecheng & "," & rs.Fields
(week_course).Value
          End If
         If rs.EOF Then
            Exit Sub
         Else
            rs.MoveNext
         End If
         course_each(i,j)=course_each(i,j) & name_string(1)& "," & Trim(kecheng)
//將已讀完的某節課安排寫入對應二維數組成員中
             End If
           End If
   Next i
Next j
2.3 課表數據的匯總

 


 在將所有課表中的數據讀出并保存到對應二維數組成員中后,就可生成總課表了。先創建EXCEL文檔,定義需要的表格格式;然后再將數據寫入對應的位置(創建總課表EXCEL文件并定義格式的程序段此處略)。下面是將數據寫入總課表的程序段。
Public Sub writeToexcel(address_file As String)
Dim xlApp As Excel.Application //EXCEL控件專用聲明
Dim xlBook As Excel.Workbook
Dim xlsheet As Excel.Worksheet

Set xlApp = CreateObject("Excel.Application")   
 //創建EXCEL對象
Set xlBook = xlApp.Workbooks.Open(address_file)    
//打開已經存在的EXCEL文件
xlApp.Visible = False                            
//設置EXCEL對象可見(或不可見)
Set xlsheet = xlBook.Worksheets("sheet1")           
//設置活動工作表
For i = 1 To 5        //第1~第5大節
   For j = 1 To 6                //星期一到星期五
   xlsheet.Cells(2 + i, 2 + j) = course_each(i, j)
     //向總課表中對應單元格寫數據
   Next j
Next i
xlBook.Save
xlBook.Close
xlApp.Quit                     //結束EXCEL對象
Set xlApp = Nothing            //釋放xlApp對象

End Sub
3 軟件界面設計
 軟件的界面主要分為菜單區、工具欄區和課表匯總結果顯示區。本系統的軟件界面的工具欄是仿OFFICE風格,并提供了一些數據處理功能。打開按鈕是指定課表所在位置,保存按鈕是將最后匯總結果以EXCEL文件的形式存到計算機中。此外,軟件還提供了剪切、復制、粘貼、撤銷、查找、插入刪除行、運行、放大、縮小、原始大小等功能按鈕,以方便使用。在軟件下方狀態欄的左邊顯示的是教師課表存放的位置,右邊顯示的是開課教師的人數。通過菜單欄中的教師名單選項還可以查看所有開課教師的詳細名單,以方便對結果的檢查和核對。系統軟件界面的主要功能區如圖3所示。

 自動匯總系統的開發,較好地實現了對課表數據的讀取和匯總,具有方便快捷的特點,大大提高了工作效率,減輕了工作人員的重復性勞動,并且提高了匯總課表的準確性。該系統在應用中效果較好。
參考文獻
[1] 徐謖,徐立.Visual Basic應用與開發案例教程[M].北京:清華大學出版社,2005:223-225.
[2] 林桂明.用VB開發中職學校國家助學金管理軟件[J]. 湖南科技學院學報,2010(8):68-71.
[3] 高春艷,李艷.Visual Basic數據庫開發關鍵技術與實例應用[M].北京:人民郵電出版社,2005:238-241.
[4] 陳虹頤,何春.VB6.0中利用ADO對象實現數據庫編程[J].甘肅科技,2007(4).

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久福利精品| 国产精品高清一区二区三区| 亚洲精品国产欧美| 国产香蕉97碰碰久久人人| 国产精品www色诱视频| 欧美连裤袜在线视频| 欧美电影免费观看高清| 老司机精品导航| 亚洲一区二区三区在线观看视频| 午夜在线一区二区| 亚洲在线不卡| 亚洲在线播放电影| 亚洲综合社区| 午夜在线视频观看日韩17c| 亚洲自拍啪啪| 亚洲欧美日韩在线高清直播| 亚洲综合精品自拍| 亚洲资源av| 午夜亚洲视频| 久久精品av麻豆的观看方式 | …久久精品99久久香蕉国产| 黄色精品一区二区| 一区二区三区自拍| 亚洲第一精品福利| 亚洲精品久久嫩草网站秘色| 亚洲精品亚洲人成人网| aaa亚洲精品一二三区| 亚洲手机成人高清视频| 午夜精品久久久久久久久久久久久| 亚洲日本欧美天堂| 亚洲靠逼com| 亚洲视频 欧洲视频| 亚洲一区欧美| 久久精品一区蜜桃臀影院| 亚洲人www| 亚洲一卡久久| 久久国产主播精品| 女人色偷偷aa久久天堂| 欧美日韩亚洲一区| 欧美劲爆第一页| 欧美揉bbbbb揉bbbbb| 国产精品视频一区二区高潮| 欧美日韩亚洲国产精品| 国产精品v亚洲精品v日韩精品| 欧美高清视频一二三区| 欧美日韩另类字幕中文| 国产精品日韩一区二区三区| 国内精品视频久久| 国产私拍一区| 亚洲大片免费看| 一本一道久久综合狠狠老精东影业| 亚洲欧洲日产国产网站| 一区二区三区高清视频在线观看| 亚洲裸体俱乐部裸体舞表演av| 亚洲成人在线免费| 伊人久久大香线| 亚洲美女在线国产| 香蕉久久a毛片| 亚洲精品欧美精品| 亚洲欧美日韩一区二区三区在线观看 | 欧美精品一区在线播放| 欧美暴力喷水在线| 国产精品国产三级国产a| 欧美天堂亚洲电影院在线观看 | 亚洲欧洲日夜超级视频| 亚洲欧美日韩国产另类专区| 亚洲国产裸拍裸体视频在线观看乱了| 久久激情综合网| 国产精品99久久久久久白浆小说| 亚洲图片欧洲图片日韩av| 久久精品久久99精品久久| 欧美精品在线观看一区二区| 国产三级欧美三级日产三级99| 国产日韩综合一区二区性色av| 国产日韩视频一区二区三区| 亚洲黄色成人久久久| 午夜国产一区| 亚洲私人黄色宅男| 欧美成人精品一区二区| 国产日产亚洲精品系列| 99re热精品| 亚洲国产专区| 99精品国产一区二区青青牛奶| 艳妇臀荡乳欲伦亚洲一区| 久久久噜噜噜久久久| 美日韩在线观看| 国产美女高潮久久白浆| 日韩一级黄色片| 亚洲精品123区| 久久国产高清| 国产精品国产馆在线真实露脸| 国产美女一区二区| 国产一区二区三区视频在线观看| 影音先锋久久久| 午夜精品影院在线观看| 亚洲性人人天天夜夜摸| 欧美国产精品| 伊人狠狠色j香婷婷综合| 亚洲欧洲av一区二区| 亚洲欧美春色| 欧美午夜精品理论片a级大开眼界| 国产区在线观看成人精品| 激情国产一区二区| 午夜精品成人在线视频| 亚洲欧美国产三级| 欧美午夜一区二区| 亚洲精品一区二区三区福利| 亚洲激情六月丁香| 久久久免费精品| 欧美日韩三级电影在线| 亚洲第一级黄色片| 亚洲激情电影在线| 欧美a级大片| 亚洲国产成人精品女人久久久| 一区二区激情| aa级大片欧美| 久久精品一区二区三区四区| 国产精品美女一区二区| 中文在线一区| 亚洲欧美综合另类中字| 欧美色欧美亚洲另类七区| 国产日韩欧美不卡| 亚洲人线精品午夜| 日韩亚洲一区在线播放| 欧美国产日韩一区二区三区| 国产精品入口66mio| 正在播放日韩| 亚洲免费中文| 国产精品视频你懂的| 午夜一区不卡| 久久夜色精品国产噜噜av| 欧美日韩色婷婷| 亚洲久久一区| 亚洲自拍三区| 国产精品永久免费观看| 午夜免费电影一区在线观看| 久久久久久久成人| 伊人蜜桃色噜噜激情综合| 亚洲精品久久在线| 欧美日韩另类丝袜其他| 亚洲调教视频在线观看| 亚洲美女诱惑| 欧美日韩一区二区在线| 宅男精品导航| 久久国产精品99精品国产| 欧美性大战久久久久久久| 一本大道久久精品懂色aⅴ| 亚洲欧美视频在线| 国产偷国产偷亚洲高清97cao| 亚洲天堂av高清| 欧美中文在线观看国产| 精品不卡视频| 99在线精品视频| 国产精品久久久久久亚洲毛片| 亚洲乱码视频| 午夜视频在线观看一区二区| 国产日韩欧美a| 亚洲精选91| 国产精品嫩草99a| 一区二区三区成人精品| 久久国产精品久久久| 在线精品高清中文字幕| 中文有码久久| 国产婷婷色综合av蜜臀av| 91久久精品日日躁夜夜躁欧美| 久久久精品国产免费观看同学| 国产精品视频网| 久久精品视频网| 欧美日韩在线精品一区二区三区| 亚洲九九精品| 久久福利毛片| 亚洲精品小视频| 久久精品国产亚洲a| 亚洲日本aⅴ片在线观看香蕉| 日韩视频在线观看免费| 国产精品久久久久久久久果冻传媒| 一区二区三区精品视频| 久久国产精品久久久| 亚洲美女av电影| 久久久久国产一区二区| 亚洲精品视频在线看| 一区二区三区精品视频在线观看| 欧美日韩美女| 久久精品国产免费| 国产精品igao视频网网址不卡日韩| 艳妇臀荡乳欲伦亚洲一区| 欧美在线视频免费播放| 最新国产精品拍自在线播放| 香港久久久电影| 国产日韩欧美a| 一区二区高清视频| 韩国一区二区在线观看| 亚洲一区二区黄色| 亚洲国产成人av在线| 欧美中文字幕在线观看| 日韩视频在线一区二区| 亚洲欧美日韩国产| 国产欧美日韩亚州综合| 在线视频亚洲欧美| 在线看片日韩|