Closed. This question needs to be more focused. It is not currently accepting answers.
Want to improve this question? Update the question so it focuses on one problem only by editing this post.
Closed 3 years ago.
Improve this question
My class project is to prompt the user for a file, that file name they input must be correct, once file is established, the first line of the file is the size of the array. Then, I have to assign each value, line by line, to the array.
Quick note** We haven't learned about buffered reader yet so I can't use that. I also can't use ArrayList, also haven't covered that yet.
Question: How do I make sure the file name they input is right? So far in class we've used while loops to check, but I'm wondering if there's a better way. I need the user to enter "investments.txt" otherwise I need to prompt them again and again. Also any points on improving existing code is very appreciated, I'm very new to this.
Code so far:
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.util.Scanner;
public class Prog07_InvestmentManager {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
System.out.println("Please enter the file name to import. Example: Investments.txt."); //prompt user
File file = new File(in.nextLine());
try {
Scanner inFile = new Scanner(new FileReader("investments.txt"));
double min = Integer.MAX_VALUE;
double max = 0;
double mean = 0;
int num = inFile.nextInt();
inFile.nextLine();
double line = 0;
int sum = 0;
int count = 0;
while (inFile.hasNextLine()) {
line=inFile.nextDouble();
sum+=line;
count++;
if(line>max)
max=line;
if(line<min)
min=line;
}
mean = (sum/count);
System.out.println("Max: "+max);
System.out.println("Min: "+min);
System.out.println("Mean: "+mean);
System.out.println();
} catch (FileNotFoundException e1) {
}
if (in.hasNextDouble()) {
double[] values = new double [(int) in.nextDouble()];
}
try {
Scanner inputFile = new Scanner(file);
double[] arr = new double[(int) in.nextDouble()];
for (int i = 0; in.hasNextDouble(); i++) {
arr[i] = in.nextDouble();
}
} catch (FileNotFoundException e) {
file = new File("investments.txt");
System.out.print("File not found.\nPlease enter the correct path if needed.");
file = new File(in.nextLine());
}
in.close();
}
}
So there are a couple issues with your code:
After you read in your file name, you should be done with the 'in' scanner for now. You are attempting to start reading your data from System.in which will cause your program to hang unless you manually enter all of your data.
You never overwrite your original file variable with the String from System.in. You don't even necessarily need the default value to begin with.
Just remove File file = new File("investments");
and String fileName = in.nextLine();
Then add File file = new File(in.nextLine()); after your prompt.
Your while loop outside of the try/catch is also problematic and can be deleted completely. Again, you're trying to read all of your data from System.in.
You're mismatching hasNextDouble() and .nextLine(). This works with your current setup because each number is on a new line, but in general you should use the same data type.
In general, you can read in an array of doubles from a file using the following:
Scanner scanner = new Scanner(file);
double arr = new double[scanner.nextInt()];
for(int i = 0; scanner.hasNextDouble(); i++) {
arr[i] = scanner.nextDouble();
}
scanner.close();
First suggestion is to use the List<> interface, instead of a primitive array
List<Double> value = new ArrayList<>();
1 & 2 Can be done easily by sorting the list, the first and last element will be the min and max respectively.
After that, it is just a matter or using a foreach loop to find the other values
for (Double element : value) {
// do math
}
Related
I need to pull integers from a text file and sum them up. I came up with this but I keep getting an error. What am I missing? I need to use a scanner class.
import java.io.File;
import java.io.FileNotFoundException;
import java.util.Scanner;
public class txtClass {
public static void main(String[] args) throws FileNotFoundException {
File txtFile = new File(//text file path//);
Scanner scan = new Scanner(txtFile);
int length = 0;
while(scan.hasNextLine()) {
scan.nextLine();
length++;
}
int array[] = new int [length];
array[length++] = scan.nextInt();
System.out.println(array.toString());
int h = 0;
for (int i = 0; i<array.length; i++)
{
h +=array[i];
}
scan.close();
System.out.print(h);
}
}
As suggested, a lot of the code is not really needed. But presumably the 'error' you get is array index out of bounds. Here:
int array[] = new int [length];
array[length++] = scan.nextInt();
So you allocate an array and immediately access off the end of the array. Let's assume length is 42. Therefore, the allocated array elements have indexes 0 to 41. You try and assign something to array[42]. I'm not sure what you're trying to do with that line.
The alternative guess (which we would not need to guess had you mentioned the actual error message) is that your counting lines leaves the scanner positioned at end of file. so the scan.nextInt() call in the assignment gets you an I/O error.
In any case, the core of the solution is something like
int sum = 0;
while (scan.hasNextInt())
sum += scan.nextInt();
No array is needed.
You wrote in your question
I keep getting an error
That would be NoSuchElementException which is thrown by this line of your code:
array[length++] = scan.nextInt();
This is because you have already scanned the entire file and therefore there is no next int.
Remember that in order for people to help you with errors thrown by your code, you need to post the actual exception and the stack trace as well as your code.
You don't need to save all the numbers in the file in an array in order to get the sum of all the numbers. However if you also want to save all the numbers but you don't know in advance how many there are, you can use a List.
Here is a minimal example of how to read the file – which I assume contains only numbers separated by whitespace – and calculate the total. Of-course you need to replace text file path with the actual path to the text file.
File txtFile = new File("text file path");
try (Scanner scan = new Scanner(txtFile)) {
int total = 0;
while (scan.hasNextInt()) {
total += scan.nextInt();
}
System.out.println("Total: " + total);
}
catch (FileNotFoundException xFileNotFound) {
xFileNotFound.printStackTrace();
}
Note that the above code uses try-with-resources.
i have a text file and i want to read the integers and doubles. I dont know how many values i have to read. The first value in the line is always the integer and the second is always the double. I want to save the value of the first line seperately.
200
11010 0.004
500 0.02
637 0.018
How to create 2 arrays and save the values, so i can use them later? I am not allowed to create a new class. I tried to use Point but cant store doubles.
Scanner scanner = new Scanner(new File(args[0]));
int cores= scanner.nextInt();
System.out.print(cores);
while (scanner.hasNext()) {
int x = scanner.nextInt();
double y = scanner.nextDouble();
System.out.printf("x");}
I' ve tried the code above but throws out Exception
You can use simple file handling approach to read the file line by line, For the first line you can use a flag to mark the line and sent the file to remote location you want to save the data. Then for all later lines you can split the string on the basis of " " (space). Post which once you have stripped the elements of the resulting array you can typecast and append the element at first index to integer array. And the second element (typecast before append) to the double array. This shall work absolutely fine with any length of file.
A demo code for the same is as following:
public class ReadLineByLine
{
public static void main(String args[])
{
try
{
FileInputStream fis=new FileInputStream("Demo.txt");
Scanner sc=new Scanner(fis);
String tempLineData = "";
int flag = 0;
String[] elements;
List<Integer> ints = new ArrayList<Integer>(
List<Float> floats = new ArrayList<Float>(
while(sc.hasNextLine())
{
if(flag == 0){
// Place the operation with the first line here
flag++;
}
tempLineData=sc.nextLine();
elements = tempLineData.split(" ");
ints.add((int)elements[0].trim());
floats.add((float)elements[1].trim());
}
sc.close();
}
catch(IOException e)
{
e.printStackTrace();
}
}
}
TL;DR-- how to get a java.util.NoSuchElementException to return a null instead of error and crash the program.
I was writing a program that is supposed to read a series of ints from a text file. In the program the amount of ints will vary each time I run it. I have written a piece of code that will read ints and I want to know how to make the java.util.NoSuchElementException not crash my program and instead return a null.
The code I have writen is as follows
public static void main(String[] args) throws IOException{
Scanner Input = new Scanner(new File("newestcode.txt"));
Integer[] digits = new Integer[100];
int h = 0;
while(true){
digits[h] = Input.nextInt();
h++;
System.out.println(digits[h]);
}
}
in case you are curious, the program I am to be writing is a sort of decryption engine for a bad encryption engine I wrote the other day
try {
digits[h] = Input.nextInt();
h++;
System.out.println(digits[h]);
}catch (NoSuchElementException e){
break;
}
First of all, if you're not sure about amount of ints in your file, don't try to store them into fixed-size array. Use ArrayList instead.
Also don't use endless loop while(true) but consider using Input.hasNext() to check if there still is something to read from file.
And one more. You're trying to print value after increment. This means that you're adding element on 0 position but trying to read it from 1 position. Make increment on the end of the loop.
Scanner Input = new Scanner(new File("newestcode.txt"));
List<Integer> digits = new ArrayList<>();
int h = 0;
while(Input.hasNetxt()){
digits.add(h, Input.nextInt());
System.out.println(digits.get(h));
h++;
}
You should use the input.hasNext() method to check whether the input has any more 'int' before using it.
In order to support any length of int elements, you cannot set the array to a fixed length of 100, you need to use an ArrayList to add elements dynamically.
Scanner input = new Scanner(new File("./newestcode.txt"));
List<Integer> digits = new ArrayList<>();
int h = 0;
while (input.hasNext()) {
digits.add(h, input.nextInt());
System.out.println(digits.get(h));
h++;
}
Note: You need to print digits[h] before increasing the h.
In my class we're using methods to calculate data from a text file. If I had a file that looked exactly like this:
Bob
25
Molly
30
Dylan
10
Mike
65
Is there anyway to pull this data from a file and then send it to a method to calculate, and then return that calculation to display on main? I'm confused as to how Java would be able to skip each line and calculate the numbers instead of the persons name. I was thinking about using inputFile.nextDouble(); and inputFile.nextLine();. But how would I be able to set a String read the lines in the text file if I'm supposed to readthose text file lines variables as doubles? Sorry for all of the questions, I've been stuck on this for a long time and it's driving me crazy >.
You should just alternately use nextLine() and nextInt()
Scanner sc=new Scanner(new File(/* Path to the file*/));
int i=0;
while(sc.hasNext())
{
if(i==0)
{
name=sc.nextLine();
}
else
{
number=sc.nextInt();
}
i=1-i;
}
I recommend you to use an ArrayList to read the full file:
Scanner s = new Scanner(new File(//Here the path of your file));
int number;
String name;
ArrayList<String> list = new ArrayList<String>();
while (s.hasNext())
{
list.add(s.nextLine());
}
Now you have all the lines of your file (as a String) so now you can operate with the full data that it's inside.
Further, the numbers are in the even lines so you can use a loop to through all the lines and check if the line that you are using now it's even or not.
for(int i = 0; i < list.size(); i++)
{
if(i%2 == 0)
{
number = Integer.parseInt(list.get(i));
//You can use the references to your methods with this number
}
else
{
name = list.get(i);
}
}
With the % you will get the rest of the division (I'm using a property of pairs numbers). With Integer.parseInt you will parse your String to int.
So now you will be able to use this numbers to operate or whatever you want.
EDIT: Here you have an example without using ArrayList. In this case I'm going to use nextLine() and nextInt() functions:
Scanner s = new Scanner(new File(//Here the path of your file));
int count = 0;
int number;
int name;
while(s.hasNext())
{
if(i%2 == 0)
{
number = s.nextInt();
s.nextLine();
//You can use the references to your methods with this number
}
else
{
name = s.nextLine();
}
count = count + 1;
}
If you have doubts about why I'm using s.nextLine() after number without storing any value you can look my answer to this question: Why isn't the scanner input working?
I expect it will be helpful for you!
Closed. This question needs details or clarity. It is not currently accepting answers.
Want to improve this question? Add details and clarify the problem by editing this post.
Closed 9 years ago.
Improve this question
public static Student[] getInput(Scanner scanner)throws FileNotFoundException
{
//change the array size by reading the input file
Student[] classList=new Student[10];
int i;
int numberOfStudents = scanner.nextInt();
while(scanner.hasNext())
{
while(numberOfStudents > classList.length)
{
//enlargeList(classList[i]);
}
for(i = 0; i <= classList.length; i++){
String studentId = scanner.nextLine();
int mark = scanner.nextInt();
classList[i] = new Student(studentId, mark);
}
}
return classList;
}
public static void main(String[] args)
{
if (args.length!=1)
{
System.out.println("Usage GradeManager inputFileName");
System.exit(1);
}
Scanner inFile=null;
try{
//do the whole try block in the lab
String fileName = args[0];
//Open a file with FileName and creaste a scanner using it
inFile = new Scanner(new File(fileName));
Student[] classList=getInput(inFile);
}
catch (FileNotFoundException fe)
{
fe.printStackTrace();
}catch(Exception e)
{
e.printStackTrace();
}finally{
if(inFile!=null)
inFile.close();
}
}
So I am trying read from a textfile that is as follows:
9
V0012345 98
V0023456 33
V0024615 51
V0089546 57
V0015348 61
V0054162 69
V0044532 87
V0031597 74
V0074615 78
First line is the number of students in the text file, all others are student number + their grade in the class. I'm trying to import these into the array classList[]. I am very new to java and object oriented stuff, so I'm sorry in advance if my code is garbage. I have omitted the enlargeList method as it works and I've tested it.
Thanks
String studentId = scanner.nextLine();
will read V0012345 98 and then
int mark = scanner.nextInt();
will read V0023456 33 and fail
try:
String line = scanner.nextLine();
//this will ignore empty lines
if(line.equals("")) continue;
String[] lineArray = line.split(" ");
String studentId = lineArray[0];
int mark = Integer.parseInt(lineArray[1]);
There are at least four problems I can see...
First, int numberOfStudents = scanner.nextInt(); won't consume the new line character, this means the next time you try and read something from the scanner, you may get the new line character (if you're reading text) or an exception of you're reading a numeric value.
Try adding scanner.nextLine() after it, for example...
int numberOfStudents = scanner.nextInt();
scanner.nextLine();
You're pre-initializing the array before you know the number of possible lines. This seems weird to me. You know ahead of time how many lines you will need to read, why not use it?
int numberOfStudents = scanner.nextInt();
scanner.nextLine();
Student[] classList = new Student[numberOfStudents];
Next, when reading the student data, you seem to be reading the entire line, the looking for an int value after it...
This would mean you are reading V0012345 98 using scanner.nextLine(), but the next call to scanner.nextInt() will encounter V0023456, which isn't a valid int value.
Instead, read the next line and create a new Scanner to parse it...
Scanner scanLine = new Scanner(line);
String studentId = scanLine.next();
int mark = scanLine.nextInt();
This is just one possible means for doing this, but I wanted to stick with the Scanner usage simply because you seem comfortable with it...
Now, somewhere in your compound loops, something gets messed up and the Scanner is getting out of sync.
Now, because we've initialised our array to the header information we read first, we can remove the compound loop in favor of something like...
while (scanner.hasNextLine() && classList.length < i) {
String line = scanner.nextLine();
Scanner scanLine = new Scanner(line);
String studentId = scanLine.next();
int mark = scanLine.nextInt();
scanLine.close();
classList[i] = new Student(studentId, mark);
i++;
}
Instead. I've left the array length check in just in case the file is lying. This means that the header can report just about any value it wants, but the loop will check for the availability of data in the file AND that we have room to read it...
This all assumes that there are no blank lines in the file you are trying to read, unlike the example you posted. If there is, you would need to add a check in and skip those lines