Topic 20 more file processing Copyright Pearson Education, 2010 Based on slides bu Marty Stepp and Stuart Reges from

Slides:



Advertisements
Similar presentations
Building Java Programs Chapter 6 File Processing Copyright (c) Pearson All rights reserved.
Advertisements

BUILDING JAVA PROGRAMS CHAPTER 6.4 FILE OUTPUT. 22 PrintStream : An object in the java.io package that lets you print output to a destination such as.
Copyright 2008 by Pearson Education Line-based file processing reading: 6.3 self-check: #7-11 exercises: #1-4, 8-11.
Files 1. 2 Storage Modern computers have many different kinds of storage components: - memory (aka RAM or DRAM) - disks (aka “hard disks” or “hard drives”)
Copyright 2008 by Pearson Education Building Java Programs Chapter 6 Lecture 6-1: File Input with Scanner reading: , 5.3 self-check: Ch. 6 #1-6.
Copyright 2006 by Pearson Education 1 Building Java Programs Chapter 6: File Processing.
1 CSE 142 Lecture Notes File input using Scanner Suggested reading: , Suggested self-checks: Section 6.7 # 1-11, These lecture.
1 Files Readings: 6.1 – Reading data from files Creating a Scanner for a file, general syntax: Scanner = new Scanner(new File(" ")); Example: Scanner.
Copyright 2006 by Pearson Education 1 Building Java Programs Chapter 6: File Processing.
Copyright 2006 by Pearson Education 1 Building Java Programs Chapter 6: File Processing.
Copyright 2006 by Pearson Education 1 Building Java Programs Chapter 6: File Processing.
Copyright 2008 by Pearson Education Building Java Programs Chapter 3 Lecture 3-3: Interactive Programs w/ Scanner reading: self-check: #16-19.
1 CSE 142 Lecture Notes Interactive Programs with Scanner Chapter 4 Suggested reading: Suggested self-checks: Section 4.10 #1-4 These lecture.
Topic 11 Scanner object, conditional execution Copyright Pearson Education, 2010 Based on slides bu Marty Stepp and Stuart Reges from
CS305j Introduction to Computing File Processing 1 Topic 18 File Processing " We have also obtained a glimpse of another crucial idea about languages and.
Copyright 2010 by Pearson Education Building Java Programs Chapter 6 Lecture 6-2: Line-Based File Input reading:
1 Hours question Given a file hours.txt with the following contents: 123 Kim Eric Stef
BUILDING JAVA PROGRAMS CHAPTER 6 File Processing.
Topic 19 file input, line based Copyright Pearson Education, 2010 Based on slides bu Marty Stepp and Stuart Reges from
1 BUILDING JAVA PROGRAMS CHAPTER 6 DETAILS OF TOKEN-BASED PROCESSING.
Week 7 Review and file processing. >>> Methods Hello.java public class Hello { public static void main(String[] args){ hello(); } public static void hello(){
Interactive Programs with Scanner. 2 Input and System.in interactive program: Reads input from the console. –While the program runs, it asks the user.
Copyright 2008 by Pearson Education Building Java Programs Chapter 6: File Processing Lecture 6-2: Advanced file input reading: self-check: #7-11.
1 Building Java Programs Chapter 6 Lecture 6-3: Section Problems reading:
CHAPTER 5 GC 101 Input & Output 1. INTERACTIVE PROGRAMS  We have written programs that print console output, but it is also possible to read input from.
FILE PROCESSING. Reading files To read a file, pass a File when constructing a Scanner. Scanner name = new Scanner(new File(" file name ")); Example:
Building Java Programs Chapter 6 Lecture 6-2: Line-Based File Input reading:
1 Reminder: String Scanners A Scanner can be constructed to tokenize a particular String, such as one line of an input file. Scanner = new Scanner( );
File Processing Copyright Pearson Education, 2010 Based on slides bu Marty Stepp and Stuart Reges from "We can only.
1 Line-based file processing suggested reading:6.3.
Copyright 2008 by Pearson Education Building Java Programs Chapter 3 Lecture 3-3: Interactive Programs w/ Scanner reading: self-check: #16-19.
Copyright 2008 by Pearson Education Building Java Programs Chapter 6 Lecture 6-3: Searching Files reading: 6.3, 6.5.
Building Java Programs Chapter 6 File Processing Copyright (c) Pearson All rights reserved.
1 Line-based file processing reading: 6.3 Use this if you seem to need line based processing for some aspects of your program and token based for others.
Building Java Programs
Building Java Programs
Building Java Programs Chapter 6
CSc 110, Autumn 2017 Lecture 20: Line-Based File Input
CSc 110, Spring 2017 Lecture 18: Line-Based File Input
CSc 110, Autumn 2017 Lecture 21: Line-Based File Input
Building Java Programs
Line-based file processing
Topic 11 Scanner object, conditional execution
Topic 20 more file processing
Building Java Programs
Building Java Programs
Building Java Programs
Building Java Programs
CSc 110, Spring 2017 Lecture 17: Line-Based File Input
Building Java Programs
CSc 110, Autumn 2016 Lecture 17: Line-Based File Input
CSc 110, Spring 2018 Lecture 22: Line-Based File Input
Building Java Programs
Chapters 6 and 7 Line-Based File Input, Arrays reading: , 7.1
Building Java Programs
CSc 110, Spring 2018 Lecture 21: Line-Based File Input
CSc 110, Autumn 2016 Programming feel like that?
Input/output (I/O) import java.io.*;
Building Java Programs
Building Java Programs
Building Java Programs
Files Readings: 6.1 – 6.2.
Building Java Programs
Building Java Programs
Topic 19 file input, line based
Building Java Programs
Building Java Programs
Building Java Programs
Building Java Programs
Optional Topic: User Input with Scanner
Presentation transcript:

Topic 20 more file processing Copyright Pearson Education, 2010 Based on slides bu Marty Stepp and Stuart Reges from "We can only see a short distance ahead, but we can see plenty there that needs to be done." - Alan Turing

Recall: Line-based methods  nextLine consumes from the input cursor to the next \n. Scanner input = new Scanner(new File(" ")); while (input.hasNextLine()) { String line = input.nextLine(); ; } MethodDescription nextLine() returns the next entire line of input hasNextLine() returns true if there are any more lines of input to read (always true for console input)

Recall: Tokenizing lines  A String Scanner can tokenize each line of a file. Scanner input = new Scanner(new File(" ")); while (input.hasNextLine()) { String line = input.nextLine(); Scanner lineScan = new Scanner(line); ; }

clicker Question  What is output by the following code if the input file contains public static void print(Scanner sc) { int total = sc.nextInt(); total += sc.nextInt(); System.out.println(total + " " + sc.nextLine()); } A.36B. 36 Christmas Eve C. 24 Christmas Eve D. no output due to syntax error E. no output due to runtime error Christmas Eve

Hours v2 question  Modify the Hours program to search for a person by ID: –Example: Enter an ID: 456 Eric worked 36.8 hours (7.36 hours/day) –Example: Enter an ID: 293 ID #293 not found

Hours v2 answer 1 // This program searches an input file of employees' hours worked // for a particular employee and outputs that employee's hours data. import java.io.*; // for File import java.util.*; // for Scanner public class HoursWorked { public static void main(String[] args) throws FileNotFoundException { Scanner console = new Scanner(System.in); System.out.print("Enter an ID: "); int searchId = console.nextInt(); // e.g. 456 Scanner input = new Scanner(new File("hours.txt")); String line = findPerson(input, searchId); if (line.length() > 0) { processLine(line); } else { System.out.println("ID #" + searchId + " was not found"); }...

Hours v2 answer 2 // Locates and returns the line of data about a particular person. public static String findPerson(Scanner input, int searchId) { while (input.hasNextLine()) { String line = input.nextLine(); Scanner lineScan = new Scanner(line); int id = lineScan.nextInt(); // e.g. 456 if (id == searchId) { return line; // we found them! } return ""; // not found, so return an empty String } // Totals the hours worked by the person and outputs their info. public static void processLine(String line) { Scanner lineScan = new Scanner(line); int id = lineScan.nextInt(); // e.g. 456 String name = lineScan.next(); // e.g. "Brad" double hours = 0.0; int days = 0; while (lineScan.hasNextDouble()) { hours += lineScan.nextDouble(); days++; } System.out.println(name + " worked " + hours + " hours (" + (hours / days) + " hours/day)"); }

IMDb movies problem  Consider the following Internet Movie Database (IMDb) data: ,400The Shawshank Redemption (1994) ,937The Godfather (1972) ,741The Godfather: Part II (1974)  Write a program that displays any movies containing a phrase: Search word? part Rank Votes Rating Title The Godfather: Part II (1974) The Departed (2006) The Apartment (1960) Spartacus (1960) 4 matches.

Recall "Chaining"  main should be a concise summary of your program. –It is generally poor style if each method calls the next without ever returning (chaining):  A better structure has main make most of the calls. –Methods must return values to main to be passed on later. main methodA methodB methodC methodD main methodA methodB methodC methodD

Bad IMDb "chained" code 1 // Displays IMDB's Top 250 movies that match a search string. import java.io.*; // for File import java.util.*; // for Scanner public class Movies { public static void main(String[] args) throws FileNotFoundException { getWord(); } // Asks the user for their search word and returns it. public static void getWord() throws FileNotFoundException { System.out.print("Search word: "); Scanner console = new Scanner(System.in); String searchWord = console.next(); searchWord = searchWord.toLowerCase(); System.out.println(); Scanner input = new Scanner(new File("imdb.txt")); search(input, searchWord); }...

Bad IMDb "chained" code 2... // Breaks apart each line, looking for lines that match the search word. public static String search(Scanner input, String searchWord) { int matches = 0; while (input.hasNextLine()) { String line = input.nextLine(); String lineLC = line.toLowerCase(); // case-insensitive match if (lineLC.indexOf(searchWord) >= 0) { matches++; System.out.println("Rank\tVotes\tRating\tTitle"); display(line); } System.out.println(matches + " matches."); } // Displays the line in the proper format on the screen. public static void display(String line) { Scanner lineScan = new Scanner(line); int rank = lineScan.nextInt(); double rating = lineScan.nextDouble(); int votes = lineScan.nextInt(); String title = ""; while (lineScan.hasNext()) { title += lineScan.next() + " "; // the rest of the line } System.out.println(rank + "\t" + votes + "\t" + rating + "\t" + title); }

Better IMDb answer 1 // Displays IMDB's Top 250 movies that match a search string. import java.io.*; // for File import java.util.*; // for Scanner public class Movies { public static void main(String[] args) throws FileNotFoundException { String searchWord = getWord(); Scanner input = new Scanner(new File("imdb.txt")); String line = search(input, searchWord); int matches = 0; if (line.length() > 0) { System.out.println("Rank\tVotes\tRating\tTitle"); while (line.length() > 0) { matches++; display(line); line = search(input, searchWord); } System.out.println(matches + " matches."); }

Better IMDb answer 2 // Asks the user for their search word and returns it. public static String getWord() { System.out.print("Search word: "); Scanner console = new Scanner(System.in); String searchWord = console.next(); searchWord = searchWord.toLowerCase(); System.out.println(); return searchWord; } // Breaks apart each line, looking // for lines that match the search word. public static String search(Scanner input, String searchWord) { while (input.hasNextLine()) { String line = input.nextLine(); // case-insensitive match String lineLC = line.toLowerCase(); if (lineLC.indexOf(searchWord) >= 0) { return line; } return ""; // not found }

Better IMDb answer 3 // Displays the line in the proper format on the screen. public static void display(String line) { Scanner lineScan = new Scanner(line); int rank = lineScan.nextInt(); double rating = lineScan.nextDouble(); int votes = lineScan.nextInt(); String title = ""; while (lineScan.hasNext()) { // the rest of the line title += lineScan.next() + " "; } System.out.println(rank + "\t" + votes + "\t" + rating + "\t" + title); }

Mixing tokens and lines  Using nextLine in conjunction with the token- based methods on the same Scanner can cause unexpected results Joe "Hello world"  You'd think you could read 23 and 3.14 with nextInt and nextDouble, then read Joe "Hello world" with nextLine. System.out.println(input.nextInt()); // 23 System.out.println(input.nextDouble()); // 3.14 System.out.println(input.nextLine()); // –But the nextLine call produces no output! Why?

Mixing lines and tokens  Avoid reading both tokens and lines from the same Scanner : Joe "Hello world" input.nextInt() // 23 23\t3.14\nJoe\t"Hello world"\n\t\t \n ^ input.nextDouble() // \t3.14\nJoe\t"Hello world"\n\t\t \n ^ input.nextLine() // "" (empty!) 23\t3.14\nJoe\t"Hello world"\n\t\t \n ^ input.nextLine() // "Joe\t\"Hello world\"" 23\t3.14\nJoe\t"Hello world"\n\t\t \n ^

Line-and-token example Scanner console = new Scanner(System.in); System.out.print("Enter your age: "); int age = console.nextInt(); System.out.print("Now enter your name: "); String name = console.nextLine(); System.out.println(name + " is " + age + " years old."); Log of execution (user input underlined): Enter your age: 12 Now enter your name: Sideshow Bob is 12 years old.  Why? –Overall input: 12\nSideshow Bob –After nextInt():12\nSideshow Bob ^ –After nextLine():12\nSideshow Bob ^