J., Thanks for your suggestions. While googling comp.unix.shell today, I found yet another method. I was not aware that "*" when used by itself matches every filename in a directory. Apparently, part of the problem I was having was a side effect of ls and find. Here is the script that I used:
#!/usr/bin/bash for file in * do newfile="`echo "$file" | tr '[:blank:]' '[_*]'`" mv "$file" "$newfile" done I also learned something important about tr. I was using [:space:], but that is not appropriate here. [:space:] includes horizontal as well as vertical whitespace. That means I was transforming linefeeds as well as spaces. [:blank:] is exclusively horizontal whitespace, which is what I needed. Thanks to all of you who contributed. I appreciate your help. Cheers, Sean On Thu, Feb 20, 2003 at 11:22:36AM +0100, J. hunted and pecked out: > On Tue, 18 Feb 2003, Theo. Sean Schulze wrote: > > > Thanks, that did help, although it didn't solve the problem. > > I now recognize that the problem is in assigning the variable. > > Both my version with ls and the version with find in the example give > > the expected results when printing to the console, > > but they both fail when used to assign a string including spaces to a > > variable. I need to find a way to maintain the integrity of the string > > as I assign it to the file variable. I tried `echo (ls -1)` and `echo > > "(ls -1)"`, but neither works. Changing the parentheses to brackets > > doesn't help either. > > > > Cheers, > > Sean > > Assigning variables does not happen in the `ls -1' statement. This only > generates strings. You need a command that read's the variables correctly. > Use `read', as in: > > ls -1 | while read file ; do echo "$file" ; done > > or > > find . -type f | while read file ; do > echo "$file" > done > > or more exotic, array version. > > IFS=$'\n' eval 'lines=( $(cat < $file) )' > # now you have a array of lines.... which can be proccessed further.. > > These all where tested and work just fine. > > G00d lUcK > > J. > > - > To unsubscribe from this list: send the line "unsubscribe linux-newbie" in > the body of a message to [EMAIL PROTECTED] > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.linux-learn.org/faqs -- Theo. Sean Schulze [EMAIL PROTECTED] - To unsubscribe from this list: send the line "unsubscribe linux-newbie" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.linux-learn.org/faqs