Problem with directory recursion!

Robert Dailey rcdailey at gmail.com
Fri Aug 17 14:19:13 EDT 2007


Here's part of the output that's incorrect:

models\W_BoomerEdge
        BYOS_C.entity.xml
        BYOS_C_Collision.entity.xml

Notice that the file BYOS_C.entity.xml is showing up as a file in the
directory W_BoomerEdge. This file does not exist in this folder, but yet in
a different folder. The output is consistent with the 'print' statements you
will see in the function I posted earlier.

On 8/17/07, Robert Dailey <rcdailey at gmail.com> wrote:
>
> Hi,
>
> I've created a function that is used to recurse a directory tree in
> Windows XP using os.walk(). For the most part it works, however in some
> instances the data is incorrect and I'm getting invalid sub-directory paths.
> Here's the function:
>
>
> def __doSearch( root_dir, sub_path, restype, ext ):
>     print sub_path
>     # Searches the specified directory and generates a
>     # list of files to preload.
>     complete_path = osp.normpath( osp.join( root_dir, sub_path ) )
>     for root, dirs, files in os.walk( complete_path ):
>
>         # Record the list of file hash ID's
>         for file in files:
>             split = __resType( file )
>             if split[1] == restype:
> #                print sub_path
>                 print "\t", file
>                 __appendResource( ext, sub_path, split[0] )
>
>         # Remove .svn subdirectories; we don't walk these.
>         if ".svn" in dirs:
>             dirs.remove( ".svn" )
>
>         # Recurse child directories
>         for dir in dirs:
>             __doSearch( root_dir, osp.join( sub_path, dir ), restype, ext
> )
>
> Does anyone see anything immediately suspicious about the code? I'm
> assuming that in Python, every time a function is called recursively it gets
> its own copy of local variables. For some reason the sub_path variable isn't
> consistent depending on where I use it. For example, if you notice the print
> call at the very start of the function, it will output something like
> "models/ships". However, after passing it into __appendResource(), it
> appears to be just "models".
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.python.org/pipermail/python-list/attachments/20070817/17c4b2ed/attachment.html>


More information about the Python-list mailing list