VB畢業課程設計報告
課程設計對我們每個人來說都是一個挑戰,下面是VB畢業課程設計報告,為大家提供參考。
課程設計題目:個人收支管理
難度:☆☆☆
姓名:***
學號:913*****0633
隨著社會生活步調的不斷加快,人們越來越繁忙。也因此各項收入和支出名目繁多,如果不善於管理常會出現入不敷出,工資感覺沒怎麼用到月底就已經全光了。所以對自己在日常生活中的收入和支出進行記錄和管理是十分必要的。這也正是設計這個程式的初衷,給人們的生活帶來便利。
一、題目介紹
個人收支管理是一款簡單家庭理財軟體,主要為使用者提供每日的收支記錄和查詢服務,還能統計總收入和總支出。
功能要求
(1) 執行程式,首先進入的是登入視窗,因收支涉及個人隱私,因此該程式要求密碼驗證。如果密碼輸入連續三次錯誤,程式自動退出。程式的初始密碼為空,即不必輸入密碼,直接單擊“確定”按鈕進入。
(2) 當用戶輸入正確密碼後,則進入程式介面。
(3) 單擊“引數設定”按鈕,進入“引數設定”視窗。該視窗有三個選項卡。
1 “收入類別””和“支出類別”選項卡主要對日常收支進行分類,可對類別進行新增,修改,刪除等處理,並將處理後的類別資訊儲存到資料夾中以供本程式的其他視窗使用。這兩個選項卡的初始狀態為:“新增”和“返回”按鈕可用,另外兩個按鈕不可用,同時文字框亦不能進行文字輸入。單擊“新增”按鈕後,文字框才能編輯,並清空原有的內容。在文字框中輸入新類別後選擇“確定”即可新增。單擊列表框中的某一項時,其內容顯示在文字框中,同時“刪除”和“修改”按鈕才可用。單擊“修改”按鈕後,在文字框中進行修改,“確定”後修改操作完成。單擊“刪除”按鈕時,從列表框中刪除所選類別。
2 透過“密碼修改”選項卡可以修改密碼。若“新密碼”和“再輸入一次”中的輸入密碼不一致,則會提示使用者重新輸入。
(4) 單擊程式主介面上的“日常流水賬”按鈕,進入日常收支的原始資料輸入視窗。該視窗主要由“收入記賬”和“支出記賬”兩個選項卡組成。考慮到流水賬的內容可能較多,因此進入該窗體時,視窗底部的列表中只顯示已收入的本月的收支情況。“收入類別”和“支出類別”使用了組合框,其中顯示了“引數設定”窗體所設定的'收入和支出類別,使用者只須從中選擇即可。新增新的收支資訊時,先在“日期”,“金額”,“收入型別”和“備註”中輸入或選擇適當內容,然後單擊“儲存”按鈕
即可,視窗底部列表框中顯示已輸入的資訊。單擊“取消”按鈕則會清空文字框中的內容。新增完畢,單擊“流水賬”視窗右上角的“返回”按鈕可返回主介面。
(5) 從主介面上選擇“查詢統計”,進入“查詢統計”視窗。該視窗由三張選項卡組成,既可以單獨統計收入或支出的情況,也可以查詢某一段時間內總的收入和支出情況。“收入查詢”和“支出查詢”根據實際需要共設定兩種查詢方式:一種是查詢某個時間段內的總收入和支出,另一種是查詢某一時間段內某一收入和支出類別的收支情況。透過“請選擇查詢方式”中的兩個單選框來選擇這兩種模式。“收入支出對比”選項卡顯示某一時間段內總的收入和支出情況。
二、課程設計的詳細說明
本程式由一個標準模組和五個窗體模組frmland 、frmmain 、frmbill、 frmquery、 frmset構成。同時有三個文字檔案分別用於儲存收入型別(Inputtype.txt)、支出型別(Outputtype.txt)和收支賬目(Balance.txt),一個檔案(Balance.pas)儲存加密後的密碼。
Frmland為啟動窗體,供使用者輸入密碼並檢驗,如果正確就顯示主窗體進入程式,如果三次輸入均不正確就關閉程式。
Frmmain為主窗體,用於各個窗體的連線和退出程式,它有四個按鈕單擊後分別顯示窗體frmbill、窗體 frmquery、窗體 frmset。
窗體frmbill供使用者輸入每日的收支帳目,即收支型別、收支時間、金額和備註。每次載入窗體frmbill時從Inputtype.txt讀出收入型別,從Outputtype.txt讀出支出型別給控制元件初始化,便於使用者選擇相應的型別輸入日常流水賬。為實現資料逐條讀寫採用do loop迴圈 EOF()檔案函式和input語句。利用If語句判斷data的int1取值,確定資料是收入還是支出,利用month()函式獲得帳目時間time1的月份,只將本月的帳目顯示在列表框裡。
窗體 frmquery供使用者進行查詢,它提供三個選項卡,分別支援收入查詢,支出查詢和收支對比查詢。使用者還可以對查詢方式進行選擇:按時間或按型別 ,為提供這2個選擇,執行時對框架控制元件的Visible 屬性進行設定。
窗體 frmset 可以由使用者自己新增收入支出型別和修改密碼,設定後將寫入檔案儲存。收入支出型別經修改後利用For迴圈遍歷列表框中的條目,將每一條寫進Inputtype.txt或Outputtype.txt。
密碼的加密按如下變換(0—A,1—B,9—J )。將密碼的每一個數字加上65後按Ascaii碼轉換為相應的字母。
用到Mid() ,Asc (),Len()函式和For迴圈。 標準模組用來宣告自定義資料型別 data ,它有5個元素:
int1 As Integer (取2個值,1表示收入,0表示支出)
time1 As Date (儲存收支時間)
moneytype As String(儲存收支型別)
money As String(儲存金額)
addition As String(儲存備註)
標準模組中宣告全域性變數 password 和 password2 分別儲存原始數字密碼和經過加密後的密碼。
三、截圖
略
四、除錯程式的過程
問題一:除錯時找不到檔案路徑,在查閱了幾本參考書後,見書中用了App.path函式來開啟檔案讀入或讀出。於是我按照書上的例子,在程式中用App.path函式找到了檔案。 問題二:除錯時資料從檔案中讀入時,出現“輸入超出檔案尾”。發現程式沒有什麼錯誤,在開啟文字檔案Balance.txt時發現游標與文字之隔著幾行空白,當刪除後,程式執行良好。說明游標的最後位置應緊鄰上次輸入的內容。
問題二:我一開始試圖用write #1 ,newdata語句一次性寫入自定義型別的所有元素,但是VB只支援隨機讀取檔案使用它,對於文字檔案,處理自定義資料型別並不方便。改寫為write #1, newdata.int1 , newdata.time1, newdata.moneytype, newdata.money , newdata.addition後才實現寫入功能。
問題三:當用戶輸入的資料型別與我設定的變數型別不統一時,會出現許多錯誤,為了方便使用者,必須新增顯式轉換語句避免錯誤
五、課程設計總結
這次課程設計雖然課題只有三顆星,但由於基礎薄弱還是費了不少功夫。我從中體會到了許多。比如一項任務開始前要有一個整體規劃,將各個模組和它們的功能想清楚,然後才能具體動手,此外還要步步最佳化,慢慢除錯才能最終完成程式設計,不能急功近利,也不能粗心大意。編寫程式的過程讓我意識到的圖書館的巨大作用,不是課堂所學都能有所用,也不是所用要用的都學習過,學會自學,學會使用圖書館是那麼重要。還有要有知難而上的勇氣和必勝的信念,遇到除錯錯誤不能灰心失望,要找到原因,積極改正。