Random Files Please see speaker notes for additional information!

Slides:



Advertisements
Similar presentations
JQuery MessageBoard. Lets use jQuery and AJAX in combination with a database to update and retrieve information without refreshing the page. Here we will.
Advertisements

P1PMF Split1 QBASIC. P1PMF Split2QBasic Command Prompt Will launch the emulator DOS operating system? Press Alt + Enter to display the widescreen.
30/04/ Selection Nested If structures & Complex Multiple Conditions.
Objectives Understand the software development lifecycle Perform calculations Use decision structures Perform data validation Use logical operators Use.
Files Organisation sequential files. Readings u Schneider Chapter 8 u Shelly Cashman to 9.14; to 9.11 u Meyer to 2-37; 1995.
IS 1181 IS 118 Introduction to Development Tools VB Chapter 06.
Creating And Maintaining A Database. 2 Learn the guidelines for designing databases When designing a database, first try to think of all the fields of.
Control Arrays, Records, and Record Arrays in V.B. Week 10.
Muffin Shop - if, calculations etc. (muffins, muffins2) Please use speaker notes for additional information!
Introduction to Class Modules Please use speaker notes for additional information!
Visual Basic Fundamental Concepts. Integrated Development Enviroment Generates startup form for new project on which to place controls. Features toolbox.
Creating Embedded Formative Assessment Dr. Steve Broskoske Misericordia University EDU 533 Computer-based Education.
Repetition Statements Repeating an Action A specified number of times While a Condition is True Until a Condition is True.
SPELLING GAME PROJECT SAMPLE ASSESSMENT MATERIAL GCSE Computing.
InvEasy (Project1) Please use speaker notes for additional information!
Break Processing Please use speaker notes for additional information!
Chapter 17: Arrays Spreadsheet-Based Decision Support Systems Prof. Name Position (123) University Name.
Chapter 7 Code Tables. VB Code Box 7-1 Event Procedure for Compute Button Private Sub hsbExemptions_Change() txtExemptions.Text =Str(hsbExemptions.Value)
08/10/ Iteration Loops For … To … Next. 208/10/2015 Learning Objectives Define a program loop. State when a loop will end. State when the For.
Programming Examples to Accompany Structure Topic Please use speaker notes for additional information!
For Loops (ProjFor1, ProjFor2, ProjFor3, ProjFor4, textbox, textbox1) Please use speaker notes for additional information!
The Repetition Process in Visual Basic. The Repetition Process The capability to repeat one or more statements as many times as necessary is what really.
Logic Structure - focus on looping Please use speaker notes for additional information!
If statements while loop for loop
Array - adding to array at run time Please see speaker notes for additional information!
Data files and databases. Need a control to browse to a file Standard controls for drive folder and list not much use The CommonDialogs control offers.
Do Loop with Interest Please see speaker notes for additional information!
Chapter Six: Working With Arrays in Visual Basic.
Arrays Code: Arrays Controls: Control Arrays, PictureBox, Timer.
© 1999, by Que Education and Training, Chapter 8, pages of Introduction to Computer Programming with Visual Basic 6: A Problem-Solving Approach.
1 Κατανεμημένες Διαδικτυακές Εφαρμογές Πολυμέσων Γιάννης Πετράκης.
Input Textboxes Input Boxes Different than textboxes Good for small amount of input (form full of textboxes is not nice) X = Inputbox(“prompt message”,
New Project in Visual Basic Please use speaker notes for additional information!
1 Flow Control II Code: Select-Case and For-Next Controls: Frames and OptionButtons.
MS Visual Basic Applications Walter Milner. Event-driven programming Standard approach for GUIs Contrast with old character interfaces – program determines.
MDI with Menu Please use speaker notes for additional information!
Chapter 16: Programming Structures Spreadsheet-Based Decision Support Systems Prof. Name Position (123) University Name.
Delivery and other DO Examples Please use speaker notes for additional information!
Notes on ADO from other projects Please use speaker notes for additional information!
1 Advanced Computer Programming Lab Calculator Project.
Using Text Files in Excel File I/O Methods. Working With Text Files A file can be accessed in any of three ways: –Sequential access: By far the most common.
Two Forms Please use speaker notes for additional information!
Lab 6 (2) Arrays ► Lab 5 (1) Exercise Review ► Array Concept ► Why Arrays? ► Array Declaration ► An Example of Array ► Exercise.
Copyright © 2001 by Wiley. All rights reserved. Chapter 6: Using Arrays Control Arrays List Arrays Finding Items in Arrays Multiple Forms 2-Dimensional.
Visual Basic for Application - Microsoft Access 2003 Programming applications using Objects.
VAT Calculator program Controls Properties Code Results.
Pay Example (PFirst98) Please use speaker notes for additional information!
Visual Basic I/O Programs (ProjRead1, ProjRead2, ProjWrite1, ProjPay) Please use speaker notes for additional information!
Maximum Profit Please use speaker notes for additional information!
Lesson 1. Security At the menu bar at the top you will see the word Tools. Click your mouse on Tools scroll down to Macro. Move the Mouse over and down.
Controlling Program Flow with Decision Structures.
Tutorial 81 Field, Record, Data File Field - a single item of information about a person, place, or thing Record - a group of related fields that contain.
Using a Database Access97 Please use speaker notes for additional information!
Sequential Processing to Update a File Please use speaker notes for additional information!
Loop Assignment There are no speaker notes to accompany this assignment.
Subroutines (PrArith, Math,projCP1, PrAdrProc, PrAdrProcFunc) Please use speaker notes for additional information!
Lab 5 Arrays ► Lab 4 Exercise Review ► Array Concept ► Why Arrays? ► Array Declaration ► An Example of Array ► Exercise.
Multiple forms - SDI & MDI Please use speaker notes for additional information!
Visual Basic - Break Processing
Processing multiple files
IE 8580 Module 4: DIY Monte Carlo Simulation
Find, filter etc with connection to Access code internally
Department Array in Visual Basic
If statements (Inven1, Inven2, Inven2a, Inven3, Inven3a)
Please use speaker notes for additional information!
VB.Net Programming Console Application
Please see speaker notes for additional information!
More on If statements (Calculate, Calculate1, Calculate2)
Introduction to Computer Programming IT-104
Loop Assignment.
Presentation transcript:

Random Files Please see speaker notes for additional information!

Random Gives a specified length to a string field. Defines a record. This says: modRInvR(modRInvR.bas) We have created a type declaration that we have stored in a BAS module.

Random To create a module, go to Project and then Add Module. Existing modules in the random directory.

Random

Dim fileOut As String Dim recordNum As Integer Dim invenRec As randomInvenRec Option Explicit Private Sub cmdClear_Click() txtItemNo.Text = "" txtItemName.Text = "" txtOnHand.Text = "" txtOnOrder.Text = "" txtReorderPt.Text = "" txtCost.Text = "" txtPrice.Text = "" txtItemNo.SetFocus End Sub Private Sub cmdExit_Click() Close #1 End End Sub Private Sub cmdWrite_Click() invenRec.itemno = txtItemNo.Text invenRec.itemname = txtItemName.Text invenRec.onhand = Val(txtOnHand.Text) invenRec.onorder = Val(txtOnOrder.Text) invenRec.reorderpt = Val(txtReorderPt.Text) invenRec.cost = Val(txtCost.Text) invenRec.price = Val(txtPrice.Text) recordNum = recordNum + 1 Put #1, recordNum, invenRec txtItemNo.SetFocus End Sub Private Sub Form_Load() fileOut = App.Path & "\Invenoutx.txt" Open fileOut For Random As #1 Len = Len(invenRec) End Sub This opens the file as a random output file. The length is specified by saying the length of the description in the BAS module. Here I dim invenRec as of the type randomInvenRec. The type I created when I defined the record in the BAS Module. Public Type randomInvenRec itemno As String * 5 itemname As String * 20 onhand As Integer onorder As Integer reorderpt As Integer cost As Single price As Single End Type

Random I keyed in 3 and clicked Retrieve. Record 3 was retrieved.

Random Option Explicit Dim fileOut As String Dim recordNum As Integer Dim invenRec As randomInvenRec Dim ErrorString As String Private Sub cmdClear_Click() txtRecRet.Text = "" txtItemNo.Text = "" txtItemName.Text = "" txtOnHand.Text = "" txtOnOrder.Text = "" txtReorderPt.Text = "" txtCost.Text = "" txtPrice.Text = "" txtRecRet.SetFocus End Sub Private Sub cmdExit_Click() Close #1 End End Sub The record number is the record number used on the record and invenRec is of the Type randomInvenRec.

Random Private Sub cmdRetrieve_Click() recordNum = Val(txtRecRet.Text) Get #1, recordNum, invenRec If Not EOF(1) Then txtItemNo.Text = invenRec.itemno txtItemName.Text = invenRec.itemname txtOnHand.Text = invenRec.onhand txtOnOrder.Text = invenRec.onorder txtReorderPt.Text = invenRec.reorderpt txtCost.Text = Format(invenRec.cost, "Currency") txtPrice.Text = Format(invenRec.price, "Currency") Else MsgBox "Record # is too big!" txtRecRet.Text = "" End If txtRecRet.SetFocus End Sub Private Sub Form_Load() fileOut = App.Path & "\Invenoutx.txt" Open fileOut For Random As #1 Len = Len(invenRec) End Sub The record number that is keyed in on the form is assigned to recordNum. Then the Get statement is issued to get the record with the matching recordNum. IF EOF is reached, the record is not on the file. The record number is past the record numbers of the records in the file. The Random file is opened and the length is given. Record name.field name

Random

I retrieved record 3 and changed on order to 15 (it used to be 5). After I keyed in the change, I clicked the Change button. I then retrieved record 3 again and it brought back the record with the change.

Random Private Sub cmdChange_Click() invenRec.itemno = txtItemNo.Text invenRec.itemname = txtItemName.Text invenRec.onhand = Val(txtOnHand.Text) invenRec.onorder = Val(txtOnOrder.Text) invenRec.reorderpt = Val(txtReorderPt.Text) invenRec.cost = Val(txtCost.Text) invenRec.price = Val(txtPrice.Text) Put #1, recordNum, invenRec cmdClear.SetFocus End Sub This is the change routine. The values in the fields are assigned to the values on the record. Then the PUT statement writes the record with its record number out on the file.

Random I entered in the data for this record and then pressed Add. Note that I did not enter the record number. This will be generated by the code. When I put in 8 under record to update and clicked retrieve, the record came back up.

Random Private Sub cmdAdd_Click() invenRec.itemno = txtItemNo.Text invenRec.itemname = txtItemName.Text invenRec.onhand = Val(txtOnHand.Text) invenRec.onorder = Val(txtOnOrder.Text) invenRec.reorderpt = Val(txtReorderPt.Text) invenRec.cost = Val(txtCost.Text) invenRec.price = Val(txtPrice.Text) If delSub = 0 Then lastRec = lastRec + 1 recordNum = lastRec Put #1, recordNum, invenRec Else recordNum = delArray(delSub) Put #1, recordNum, invenRec delSub = delSub - 1 End If cmdClear.SetFocus End Sub This takes the keyed in information and moves it to fields on the record. I keep track of deleted records in an array controlled by delSub. If no records are deleted then the record number becomes the last record written + 1. If there are deleted records in the array then the last record number put in the array provides the record number for this record. Note that since it is used, delSub is decreased by 1.

Random I retrieved record 6 and then clicked Delete. I then tried to retrieve record 6 and was told that the record had been deleted.

Random Private Sub cmdDelete_Click() invenRec.itemno = " " invenRec.itemname = "Deleted" invenRec.onhand = 0 invenRec.onorder = 0 invenRec.reorderpt = 0 invenRec.cost = 0 invenRec.price = 0 Put #1, recordNum, invenRec delSub = delSub + 1 delArray(delSub) = recordNum cmdClear.SetFocus End Sub The information on the record that is being deleted is resent to spaces and 0 and the name field is set to Deleted. The record on the file is written over with this cleared information. The delSub is then incremented by 1 and the record number of the deleted record is written to the array. Dim delArray(1 To 100) As Integer Dim delSub As Integer This array was defined in the general/declarations area of the program.

Random This record is the ninth record that I keyed in. However I deleted record 6 prior to keying this record in. Therefore because of the delete array, this record was assigned a record number of 6.

Random Added record. Next available record number is 9 since the only record I delete was record 6 and that number has already been used.

Random Option Explicit Dim fileIO As String Dim fileDel As String Dim recordNum As Integer Dim recordNumOfDel As Integer Dim invenRec As randomInvenRec Dim delRec As randomDel Dim delArray(1 To 100) As Integer Dim delSub As Integer Dim ErrorString As String Dim lastRec As Integer These two descriptions refer to the types defined in the BAS modules.

Random Private Sub Form_Load() Dim lenFile fileIO = App.Path & "\Invenoutx.txt" Open fileIO For Random Access Read Write As #1 Len = Len(invenRec) lenFile = LOF(1) lastRec = lenFile / Len(invenRec) fileDel = App.Path & "\InvenDelx.txt" Open fileDel For Random Access Read As #2 Len = Len(delRec) delSub = 0 Get #2, 1, delRec If Not EOF(2) Then Do delSub = delSub + 1 delArray(delSub) = Val(delRec.recnoDel) Get #2, delSub + 1, delRec Loop Until EOF(2) End If Close #2 End Sub The form load code opens the data file for Random Access Read Write and gives a length of the invenRec which is of type randomInvenRec. It then uses LOF(1) to find the length of the file and divides this by the length of the record to get the lastRec which is the record number of the last record. The form load code then opens the file that contains the record numbers of the deleted records. It then attempts to read a record. If it is successful (in other words EOF(2) is not true, then a DO loop is performed that will fill the delArray with the record numbers from the file. The name of the field and record.

Random Private Sub cmdExit_Click() Close #1 Kill fileDel Open fileDel For Random Access Write As #2 Len = Len(delRec) If delSub > 0 Then For recordNumOfDel = 1 To delSub delRec.recnoDel = Str(delArray(recordNumOfDel)) Put #2, recordNumOfDel, delRec Next recordNumOfDel End If Close #2 End End Sub The file called fileDel is killed which means that it no longer exists. The file is then opened to Write. If there are records in the array, these records are written to the file one at a time using the FOR loop that accomplishes the PUT. The regular data file is closed.

Random Private Sub cmdRetrieve_Click() recordNum = Val(txtRecRet.Text) Get #1, recordNum, invenRec If Not EOF(1) Then txtItemNo.Text = invenRec.itemno txtItemName.Text = invenRec.itemname txtOnHand.Text = invenRec.onhand txtOnOrder.Text = invenRec.onorder txtReorderPt.Text = invenRec.reorderpt txtCost.Text = invenRec.cost txtPrice.Text = invenRec.price Else MsgBox "Record # is too big!" txtRecRet.Text = "" End If txtRecRet.SetFocus End Sub The keyed in record number is moved to recordNum and then the get is done using recordNum and the name of the data record. If the read is successful, in other words it is not EOF, the the data on the record is transferred to the screen. If the record number is past EOF, then a message box is displayed.

Random Private Sub cmdClear_Click() txtRecRet.Text = "" txtItemNo.Text = "" txtItemName.Text = "" txtOnHand.Text = "" txtOnOrder.Text = "" txtReorderPt.Text = "" txtCost.Text = "" txtPrice.Text = "" txtRecRet.SetFocus End Sub Clears the boxes on the screen to null.