DaniWeb IT Discussion Community

DaniWeb IT Discussion Community (http://www.daniweb.com/forums/index.php)
-   Java (http://www.daniweb.com/forums/forum9.html)
-   -   Recursive File List - Help me problem solve please (http://www.daniweb.com/forums/thread167285.html)

caps_lock Jan 9th, 2009 3:15 pm
Recursive File List - Help me problem solve please
 
Hello

My recursive file scan is not doing what I want it to do.

I want it to be able to go through all roots (drives)...

With no user intervention, so without including "C:\\" or "." as a string in the source, or without a TextIO.java class.

import java.io.*;
import java.util.*;
 
public class RecursiveFileListAttemp1 {
    public static void main(String[] args) {
        File f = new File("C:\\"); 
        search(f);
    }

    public static void search(File f) { 
        if ( !f.exists() ) return;
        String name = f.getName();
        if ( f.isDirectory() ) {
        File[] files = f.listFiles();
        for( int i = 0 ; i < files.length; i++ ) {
        search( files[i] );
            }
        }
    }
}

At the moment I just get a null pointer exception...

I dont understand where Ive gone wrong in the code:
if its a file --> return the file name --> if its a directory --> list the files in the directory

Help please!

puneetkay Jan 9th, 2009 3:32 pm
Re: Recursive File List - Help me problem solve please
 
Hello,

Code is working perfectly! No NPException. Using Eclipse SDK Version: 3.4.0.

Best of luck!

masijade Jan 9th, 2009 3:46 pm
Re: Recursive File List - Help me problem solve please
 
File has a method that returns all the system "roots". See the API docs for File.

caps_lock Jan 9th, 2009 9:19 pm
Re: Recursive File List - Help me problem solve please
 
really thats interesting punnetkay i wonder why

but it needs to work for me!

post above: thanks for that, but I dont want to list the roots I want to list the files and files in directories that are in all directories on a computer.

I think Ive got some stable code now. But I still want to know how to recursive scan the whole computer and not just a drive. At the moment I'm able to scan "C:\\" or "D:\\" and not both, does any one know how I can make that work?

masijade Jan 10th, 2009 1:55 am
Re: Recursive File List - Help me problem solve please
 
Quote:

Originally Posted by caps_lock (Post 774850)
post above: thanks for that, but I dont want to list the roots I want to list the files and files in directories that are in all directories on a computer.

Then what was this?

Quote:

Originally Posted by caps_lock (Post 774657)
I want it to be able to go through all roots (drives)...

With no user intervention, so without including "C:\\" or "." as a string in the source, or without a TextIO.java class.

As that is the part I was responding to. You will need to use that.

Quote:

I think Ive got some stable code now. But I still want to know how to recursive scan the whole computer and not just a drive. At the moment I'm able to scan "C:\\" or "D:\\" and not both, does any one know how I can make that work?
See above. You can only "recursively" scan each drive/root one at a time. But you can loop over what the above mentioned method returns.

Why does no one ever listen to what I say?

puneetkay Jan 10th, 2009 7:23 am
Re: Recursive File List - Help me problem solve please
 
Hello again,

And again its working fine for me.

        public static void main(String[] args) {
        for(File file : File.listRoots()){ // listRoots() method return list of drives. array of File type.
                search(file);
        }
    }

    public static void search(File f) { 
        if ( !f.exists() ) return;
        String name = f.getName();
        System.out.println(name);
        if ( f.isDirectory() ) {
        File[] files = f.listFiles();
        for( int i = 0 ; i < files.length; i++ ) {
        search( files[i] );
            }
        }
    }

Regards,

masijade Jan 10th, 2009 3:27 pm
Re: Recursive File List - Help me problem solve please
 
The NPE (as the OP already knows from his post on www.java-forums.com (or is it org?)) is because listFiles will return null on an empty directory so he needs to add an if statement to check for that.

caps_lock Jan 10th, 2009 8:02 pm
Re: Recursive File List - Help me problem solve please
 
can I add a equals() statement in the code above and from that print to the terminal window files that occur on more than one instance on the recursive scan?

~s.o.s~ Jan 11th, 2009 1:45 am
Re: Recursive File List - Help me problem solve please
 
Detection of duplicate files isn't that simple; refer a similar thread. If that's not what you intend, a bit more explanation is needed.

caps_lock Jan 11th, 2009 8:12 pm
Re: Recursive File List - Help me problem solve please
 
lol i started that thread but ignore that one for now lol

anyways

thanks masijade for your reply

i tried something new

modified code below

     public static void search(File f) {
        if ( !f.exists() ) return;
        String name = f.getName();
        System.out.println(name);
        if ( f.isDirectory() ) {
        File[] files = f.listFiles();
        if (files != null) {
        for( int i = 0 ; i < files.length; i++ ) {
        search( files[i] );
        } if (f.length() <= 1) return;
                }
               

            }
        }

well to the code ive added the following line:


 if (f.length() <= 1) return;



but i dont think it has had any change in the list of results brought to the terminal window

can some one with more java knowledge tell me why please? any help or correction welcomed!


All times are GMT -4. The time now is 4:31 pm.

Forum system based on vBulletin Copyright ©2000 - 2009, Jelsoft Enterprises Ltd.
©2003 - 2009 DaniWeb® LLC