• 0

Java: Reading File & Loop help


Question

Hi... I'm a newbie at Java, so I was wondering if you guys could help me out...

I have txt file i'm reading scores and labels off of to make a bar graph.

First line is an integer (score), second line is the label ("Score 1"), and they alternate from then on. I have 5 scores, meaning ten lines in the txt file.

Anyway, I can read the txt file and make the bar graph perfectly, but when i make the loop, i always have to specify how many times to do the loop... I have no idea how to make it count how many items are in the txt file automatically or to stop when there are no more values.

Please help if you can :o

Here is my code for the loop area so far:

 int n = 0;
  int itemCount = 5;

  SimpleReader reader = new SimpleReader( "graphdata.dat" );

  while ( n < itemCount )
 	 {
 	 double number = reader.getInt();
 	 r = new SimpleRectangle( BAR_START, barPos, (int) number, BAR_HEIGHT );
 	 r.setColor( barColor );
 	 r.setToFill();
 	 graphWin.add( r );
 	 total = total + number;
 	 n = n + 1;
 	 barPos = barPos + BAR_HEIGHT + BAR_SPACER;

 	 String word = reader.getString();
 	 lab = new SimpleLabel( LABEL_START, labelPos, LABEL_WIDTH, LABEL_HEIGHT );
 	 lab.setText( word + ": " + (int) number );
 	 graphWin.add( lab );
 	 labelPos = labelPos + LABEL_HEIGHT + LABEL_SPACER;
 	 }
  reader.safeClose();

Link to comment
https://www.neowin.net/forum/topic/62996-java-reading-file-loop-help/
Share on other sites

6 answers to this question

Recommended Posts

  • 0

Well, I've got no idea what SimpleReader is, but if it's extending BufferedReader, reader.ready() will say if the file is ready or not.

So:

while(reader.ready()) {
........

or

while(reader.getInt() != *numberhere*)

If it returns an error number, just put that in the *numberhere*

It's hard though not knowing what your reader does or what methods it has to read the file with.

Edited by kjordan2001
  • 0

Use BufferedReader instead and to for the this question:

"or to stop when there are no more values"

use a while loop if the following code:

while (in.readLine() != null)
{
    //Code execution here
}

This code below is what i did some while back and should give you some hints on how to implement BufferedReader:

/**
 * Read Class - A Class that Read's a Text file
 * @author Saad Mahamood 
 * @version 10/10/02 
 */

import java.io.*;

public class Read  
{

    public Read()
    {
        //Default Constructor
    }


    /**
     * textFile - This method read's a text file and output's
     *            it's content's to the terminal
     *@execption - IOException 
     */
    public void textFile() throws IOException
    {
        File aFile = new File("read.txt");

        if ((!aFile.isFile()) || (!aFile.canRead()))
        {
            // Let's leave
            throw new IOException("File not found");
        }

            
        BufferedReader in = new BufferedReader(new FileReader(aFile));
        
        
        String theString = null;

        for (int i=0;i < 26; i++ ) 
        {
            theString = in.readLine();
            System.out.println(theString);
       	 
        }


    }



	public static void main(String[] args) 
	{
  System.out.println("Reading file");
        System.out.println("***********************");
        Read aread = new Read();
        try
        {
            aread.textFile();
        }
        catch(IOException e)
        {
            System.err.println("Anption occured!");
        }

	}
}

ss1.

  • 0

try {
    BufferedReader oBuffer = new BufferedReader(new FileReader(new File("Path\to\file.txt")));
} catch (FileNotFoundException e) {
    system.out.print("FileFound");
}

String s = null;
while(true) {
    s = oBuffer.readLine();
    if (s == null) break;

    //Do your Rectangle business here
}

BTW: IF you are finding you have to create your own readers and writers and you are a newbie, then you are going down the wrong path. The book "Core Java2" from Sun Press has a good chapter that deals with the intricacies of Readers and Writers (and InputStreams and OutputStreams). I suggest you read it. It will spare you a lot of time later down the line.

Also, try not to initialize your objects inside of a loop. You have a line

String word = reader.getString();

inside your loop. That is not very efficient. While not technically wrong, it is a bad habit to get into.

FREE TIP: (and off-topic) On a related note, careful with string concatenation inside loops. You don't do it on the example you supplied, but if you are reading a file the last thing you want to do is:

String s = new String();
String temp = null;
while (true) {
    temp = oBuffer.readLine();
    if (temp == null) break;
    s += temp;
}

If you read the book above, or any text on the net, you will learn to use a StringBuffer for this kind of operation.

Edited by PeterHammer
  • 0

sorry for the lack of reply the past few days, i haven't had a chance to jump back on the computer...

thanks for all your help... I'm a total newbie to Java, and i just found out how stupid it was to post the code that I have, since I found out that SimpleReader and all that stuff were custom classes from my teacher. sorry about that.

thanks for all your help though, i got it working now =)

thanks for all your help with BifferedReader also, I think i'm gonna study up on that one more... I'll read up a bit more before I ask for the next question.

Thanks again, and I really appreciate all of your help guys. :D

This topic is now closed to further replies.
  • Recently Browsing   0 members

    • No registered users viewing this page.
  • Posts

    • Libtards will be so excited! 🤣
    • I agree, if Intel wants to make those 50% margins, they really should stick to sockets longer, someone is more likely to upgrade their CPU when they don't need to purchase a motherboard, then looking at maybe RAM, might as well buy a whole new PC at that point, then before you know they've talked themselves out of the whole thing.
    • not sure why people care about the developers so much. let them do whatever they want. if it succeeds, it can benefit us. if it doesn't, then who cares, your life will go on. i'm glad there are still people who do things without thinking whether the output will be productive to society...
    • this man really knows how to embarass americans! i thought he was platforming on "bringing back respect to america!". really sad to see the grip he has over working class americans. he could (and i might argue already has) spit on the working class and half would kiss his shoe. at least this you gotta give him credit for. who else can do this with applause and cheer.
    • Get this 27-inch ASUS VA279QG 120Hz monitor for dirt-cheap by Taras Buria If you are on a very tight budget but you still want to upgrade your monitor to something more exciting than a standard 60Hz office monitor, ASUS has a perfect deal for you. The VA279QG is currently available for as little as $109, and for this money, you get quite a lot of a monitor. The ASUS VA279QG is a big 27-inch IPS monitor with a classic FullHD resolution and a wide 178-degree viewing angle. It can operate with a refresh rate of 120Hz, which is more than enough for buttery-smooth gaming. And since the monitor is FullHD, you will be able to see high refresh rates in more games since your GPU will have to render fewer pixels at 120Hz. Besides, the monitor supports variable refresh rate (VRR), a feature that can further reduce stutters by dynamically adjusting the refresh rate to your FPS. Other display specs include a 1ms MPRT response time, 16.7 million colors, 99% sRGB coverage, and a typical brightness of 300 nits. It is also covered with an anti-glare coating to reduce reflections. Ports-wise, you get one DisplayPort 1.2, one HDMI 1.4, one VGA, and one headphone jack. There are also two 2W speakers, but set your expectation right—these are unlikely to blow your mind with high-quality audio. Finally, there is a VESA 100 mount and a cutout in the base, which lets you mount your phone, namecard, or other small items for extra convenience. 27-inch ASUS VA279QG 120Hz IPS Gaming Monitor - $109 | 22% off on Amazon US This Amazon deal is US-specific and not available in other regions unless specified. If you don't like it or want to look at more options, check out the Amazon US deals page here. Get Prime (SNAP), Prime Video, Audible Plus or Kindle / Music Unlimited. Free for 30 days. As an Amazon Associate, we earn from qualifying purchases.
  • Recent Achievements

    • Explorer
      treker_ed went up a rank
      Explorer
    • Apprentice
      CHUNWEI went up a rank
      Apprentice
    • Veteran
      1337ish went up a rank
      Veteran
    • Rookie
      john.al went up a rank
      Rookie
    • Week One Done
      patrickft456 earned a badge
      Week One Done
  • Popular Contributors

    1. 1
      +primortal
      652
    2. 2
      ATLien_0
      269
    3. 3
      +FloatingFatMan
      176
    4. 4
      Michael Scrip
      155
    5. 5
      Steven P.
      136
  • Tell a friend

    Love Neowin? Tell a friend!