Re: How to delete a ast character from a string?
- From: norseman <norseman@xxxxxxxxxx>
- Date: Fri, 29 Aug 2008 17:28:42 -0700
dudeja.rajat@xxxxxxxxx wrote:
On Fri, Aug 29, 2008 at 7:40 PM, Chris Rebert <cvrebert+clp@xxxxxxxxx> wrote:On Fri, Aug 29, 2008 at 11:25 AM, <dudeja.rajat@xxxxxxxxx> wrote:Hi,You san simplify that line to just:
I've a list some of whose elements with character \.
I want to delete this last character from the elements that have this
character set at their end,
I have written a small program, unfortunately this does not work:
dirListFinal = []
for item in dirList:
print item
if item.endswith('\\') == True:
if item.endswith('\\'):
item = item[0:-1] # This one I googled andAnd you don't need the leading 0, so just use:
found to remove the last character /
item = item[:-1]
dirListFinal.append(item)And those last 3 lines are a bit redundant. Just put one
else:
dirListFinal.append(item)
dirListFinal.append(item)
at the same indentation level as the "if" and delete those 3 lines.
Not that these changes will necessarily fix your program, but they do
make it easier to comprehend for the reader.
- Chris
item.endswith() does not seem to be working.
Please help
--
Regrads,
Rajat
--
http://mail.python.org/mailman/listinfo/python-list
Thanks for the suggestions.
I wondered if the item is really a string. So I added the following to
check this:
item = ""
for item in dirList:
print type(item)
if item.endswith('\\'):
item = item[:-1]
dirListFinal.append(item)
Though item.endswith() is not workin still. The type of item is
appearing to be <type 'str'>
So this confirms this is a string. But why the string operation
endswith() is not working.
Really strange.
--
http://mail.python.org/mailman/listinfo/python-list
==============================
depending on OS and other factors, the DirList may be more like:
ABDIR\ 41 42 44 49 52 5C 0A
nextDir
If so endswith needs to look for \\ and \n
or just
if item[:-2] == '\x5C\x0A':
item=item[:-2]
Best to dump a test line to hex and see what you are actually dealing with. This is nearly a daily thing for me.
EOL Microsoft 0D0A
EOL Unix 0A
EOL Mac 0D
and the programmers that wrote the read and /or write routines vary widely in their handling of EOLs. Some remember to strip the 0A but leave the 0D and some do the opposite and some just add/remove 2 bytes without checking. Never know what you are going to wind up with. If your files are from varied sources, put a test for each in the front of the section and set/use variables to control how many things you need to remove. (-1,-2 or -3 for 0,1 or 2 EOL bytes respectively since you seem to be removing the continuation marker)
Depending on what you used to acquire the list be advised that Python has routines that cook the data. Not all but some. So that line just read may not contain what it appears to. Examples of this have appeared in this mail list recently. Choose your routines carefully.
It is very easy to get into a singular mindset and not consider the rest of the Universe. We all do it. If you want purity of form you will have to sacrifice efficiency. Also true in reverse.
Steve
norseman@xxxxxxxxxx
.
- Prev by Date: Re: Can I write a binary windows executable with Python?
- Next by Date: Re: posix semaphore support?
- Previous by thread: Re: Can I write a binary windows executable with Python?
- Next by thread: Re: Which is faster?
- Index(es):
Relevant Pages
|