Right solution to unicode error?

A

Anders

I've run into a Unicode error, and despite doing some googling, I
can't figure out the right way to fix it. I have a Python 2.6 script
that reads my Outlook 2010 task list. I'm able to read the tasks from
Outlook and store them as a list of objects without a hitch. But when
I try to print the tasks' subjects, one of the tasks is generating an
error:

Traceback (most recent call last):
File "outlook_tasks.py", line 66, in <module>
my_tasks.dump_today_tasks()
File "C:\Users\Anders\code\Task List\tasks.py", line 29, in
dump_today_tasks
print task.subject
UnicodeEncodeError: 'ascii' codec can't encode character u'\u2013' in
position 42: ordinal not in range(128)

(where task.subject was previously assigned the value of
task.Subject, aka the Subject property of an Outlook 2010 TaskItem)

From what I understand from reading online, the error is telling me
that the subject line contains an en dash and that Python is trying
to convert to ascii and failing (as it should).

Here's where I'm getting stuck. In the code above I was just printing
the subject so I can see whether the script is working properly.
Ultimately what I want to do is parse the tasks I'm interested in and
then create an HTML file containing those tasks. Given that, what's
the best way to fix this problem?

BTW, if there's a clear description of the best solution for this
particular problem – i.e., where I want to ultimately display the
results as HTML – please feel free to refer me to the link. I tried
reading a number of docs on the web but still feel pretty lost.

Thanks,
Anders
 
P

Prasad, Ramit

Anders said:
I've run into a Unicode error, and despite doing some googling, I
can't figure out the right way to fix it. I have a Python 2.6 script
that reads my Outlook 2010 task list. I'mable to read the tasks from
Outlook and store them as a list of objects without a hitch. But when
I try to print the tasks' subjects, one of the tasks is generating an
error:

Traceback (most recent call last):
File "outlook_tasks.py", line 66, in <module>
my_tasks.dump_today_tasks()
File "C:\Users\Anders\code\Task List\tasks.py", line 29, in
dump_today_tasks
print task.subject
UnicodeEncodeError: 'ascii' codec can't encode character u'\u2013' in
position 42: ordinal not in range(128)

(where task.subject was previously assigned the value of
task.Subject, aka the Subject property of an Outlook 2010 TaskItem)

From what I understand from reading online, the error is telling me
that the subject line contains an en dash and that Python is trying
to convert to ascii and failing (as it should).

Here's where I'm getting stuck. In the code above I was just printing
the subject so I can see whether the script is working properly.
Ultimately what I want to do is parse the tasks I'm interested in and
then create an HTML file containing those tasks. Given that, what's
the best way to fix this problem?

BTW, if there's a clear description of the best solution for this
particular problem - i.e., where I want to ultimately display the
results as HTML - please feel free to refer me to the link. I tried
readinga number of docs on the web but still feel pretty lost.

You can always encode in a non-ASCII codec.
`print task.subject.encode(<encoding>)` where <encoding> is something that
supports the characters you want e.g. latin1.

The list of built in codecs can be found:
http://docs.python.org/library/codecs.html#standard-encodings


~Ramit



This emailis confidential and subject to important disclaimers and
conditions including on offers for the purchase or sale of
securities, accuracy and completeness of information, viruses,
confidentiality, legal privilege, and legal entity disclaimers,
available at http://www.jpmorgan.com/pages/disclosures/email.
 
O

Oscar Benjamin

Traceback (most recent call last):
File "outlook_tasks.py", line 66, in <module>
my_tasks.dump_today_tasks()
File "C:\Users\Anders\code\Task List\tasks.py", line 29, in
dump_today_tasks
print task.subject
UnicodeEncodeError: 'ascii' codec can't encode character u'\u2013' in
position 42: ordinal not in range(128)

Here's where I'm getting stuck. In the code above I was just printing
the subject so I can see whether the script is working properly.
Ultimately what I want to do is parse the tasks I'm interested in and
then create an HTML file containing those tasks. Given that, what's
the best way to fix this problem?

Are you using cmd.exe (standard Windows terminal)? If so, it does not
support unicode and Python is telling you that it cannot encode the
string in a way that can be understood by your terminal. You can try
using chcp to set the code page to something that works with your
script.

If you are only printing it for debugging purposes you can just print
the repr() of the string which will be ascii and will come out fine in
your terminal. If you want to write it to a html file you should
encode the string with whatever encoding (probably utf-8) you use in
the html file. If you really just want your script to be able to print
unicode characters then you need to use something other than cmd.exe
(such as IDLE).


Oscar
 
A

Andrew Berg

Are you using cmd.exe (standard Windows terminal)? If so, it does not
support unicode
Actually, it does. Code page 65001 is UTF-8. I know that doesn't help
the OP since Python versions below 3.3 don't support cp65001, but I
think it's important to point out that the Windows command line system
(it is not unique to cmd) does in fact support Unicode.
 
S

Steven D'Aprano

I've run into a Unicode error, and despite doing some googling, I can't
figure out the right way to fix it. I have a Python 2.6 script that
reads my Outlook 2010 task list. I'm able to read the tasks from Outlook
and store them as a list of objects without a hitch. But when I try to
print the tasks' subjects, one of the tasks is generating an error:

Traceback (most recent call last):
File "outlook_tasks.py", line 66, in <module>
my_tasks.dump_today_tasks()
File "C:\Users\Anders\code\Task List\tasks.py", line 29, in
dump_today_tasks
print task.subject
UnicodeEncodeError: 'ascii' codec can't encode character u'\u2013' in
position 42: ordinal not in range(128)


This error confuses me. Is that an exact copy and paste of the error, or
have you edited it or reconstructed it? Because it seems to me that if
task.subject is a unicode string, as it appears to be, calling print on
it should succeed:

py> s = u'ABC\u2013DEF'
py> print s
ABC–DEF

What does type(task.subject) return?
 
O

Oscar Benjamin

Actually, it does. Code page 65001 is UTF-8. I know that doesn't help
the OP since Python versions below 3.3 don't support cp65001, but I
think it's important to point out that the Windows command line system
(it is not unique to cmd) does in fact support Unicode.

I have tried to use code page 65001 and it didn't work for me even if
I did use a version of Python (possibly 3.3 alpha) that claimed to
support it. It turned out that there were other Windows related
problems with using the codepage so that I had to do something like

chcp 65001 && python myscript.py && chcp 2521

(It was important for all those commands to be on the same line) I'm
not on Windows right now and I can't remember all the details but I
seem to remember that even with that awkwardness and changing the font
it still didn't actually work.

If you know how to make it work, I'd be interested to know.


Oscar
 
W

wxjmfauth

Le mercredi 7 novembre 2012 23:17:42 UTC+1, Anders a écrit :
I've run into a Unicode error, and despite doing some googling, I

can't figure out the right way to fix it. I have a Python 2.6 script

that reads my Outlook 2010 task list. I'm able to read the tasks from

Outlook and store them as a list of objects without a hitch. But when

I try to print the tasks' subjects, one of the tasks is generating an

error:



Traceback (most recent call last):

File "outlook_tasks.py", line 66, in <module>

my_tasks.dump_today_tasks()

File "C:\Users\Anders\code\Task List\tasks.py", line 29, in

dump_today_tasks

print task.subject

UnicodeEncodeError: 'ascii' codec can't encode character u'\u2013' in

position 42: ordinal not in range(128)



(where task.subject was previously assigned the value of

task.Subject, aka the Subject property of an Outlook 2010 TaskItem)



From what I understand from reading online, the error is telling me

that the subject line contains an en dash and that Python is trying

to convert to ascii and failing (as it should).



Here's where I'm getting stuck. In the code above I was just printing

the subject so I can see whether the script is working properly.

Ultimately what I want to do is parse the tasks I'm interested in and

then create an HTML file containing those tasks. Given that, what's

the best way to fix this problem?



BTW, if there's a clear description of the best solution for this

particular problem – i.e., where I want to ultimately display the

results as HTML – please feel free to refer me to the link. I tried

reading a number of docs on the web but still feel pretty lost.



Thanks,

Anders

----------


The problem is not on the Python side or specific
to Python. It is on the side of the "coding of
characters".

1) Unicode is an abstract entity, it has to be encoded
for the system/device that will host it.
Using Python:
<unicode>.encode(host_coding)

2) The host_coding scheme may not contain the
character (glyph/grapheme) corresponding to the
"unicode character". In that case, 2 possible
solutions, "ignore" it ou "replace" it with a
substitution character.
Using Python:
<unicode>.encode(host_coding, "ignore")
<unicode>.encode(host_coding, "replace")

3) Detecting the host_coding, the most difficult
task. Either you have to hard-code it or you
may expect Python find it via its sys.encoding.

4) Due to the nature of unicode, it the unique
way to do it correctly.

Expectedly failing and not failing examples.
Mainly Py3, but it doesn't matter. Note: Py3 encodes
and creates a byte string, which has to be
decoded to produce a native (unicode) string, here
with cp1252.


Py2

Traceback (most recent call last):
File "<pyshell#0>", line 1, in <module>
u'éléphant\u2013abc'.encode('ascii')
UnicodeEncodeError: 'ascii' codec can't encode character u'\xe9' in position 0: ordinal not in range(128)
Traceback (most recent call last):
File "<eta last command>", line 1, in <module>
UnicodeEncodeError: 'ascii' codec can't encode character '\xe9' in
position 0: ordinal not in range(128)
'éléphant–abc'
'éléphant–abc'

etc

jmf
 
H

Hans Mulder

This error confuses me. Is that an exact copy and paste of the error, or
have you edited it or reconstructed it? Because it seems to me that if
task.subject is a unicode string, as it appears to be, calling print on
it should succeed:

py> s = u'ABC\u2013DEF'
py> print s
ABC–DEF

That would depend on whether python thinks sys.stdout can
handle UTF8. For example, on my MacOS X box:

$ python2.6 -c 'print u"abc\u2013def"'
abc–def
$ python2.6 -c 'print u"abc\u2013def"' | cat
Traceback (most recent call last):
File "<string>", line 1, in <module>
UnicodeEncodeError: 'ascii' codec can't encode character u'\u2013' in
position 3: ordinal not in range(128)

This is because python knows that my terminal is capable
of handling UTF8, but it has no idea whether the program at
the other end of a pipe had that ability, so it'll fall
back to ASCII only if sys.stdout goes to a pipe.

Apparently the OP has a terminal that doesn't handle UTF8,
or one that Python doesn't know about.


Hope this helps,

-- HansM
 
A

Anders Schneiderman

Thanks, Oscar and Ramit! This is exactly what I was looking for.

Anders

-----Original Message-----
From: Oscar Benjamin [mailto:eek:[email protected]]
Sent: Wednesday, November 07, 2012 6:27 PM
To: Anders Schneiderman
Cc: (e-mail address removed)
Subject: Re: Right solution to unicode error?

Traceback (most recent call last):
File "outlook_tasks.py", line 66, in <module>
my_tasks.dump_today_tasks()
File "C:\Users\Anders\code\Task List\tasks.py", line 29, in
dump_today_tasks
print task.subject
UnicodeEncodeError: 'ascii' codec can't encode character u'\u2013' in
position 42: ordinal not in range(128)

Here's where I'm getting stuck. In the code above I was just printing
the subject so I can see whether the script is working properly.
Ultimately what I want to do is parse the tasks I'm interested in and
then create an HTML file containing those tasks. Given that, what's
the best way to fix this problem?

Are you using cmd.exe (standard Windows terminal)? If so, it does not
support unicode and Python is telling you that it cannot encode the string in a
way that can be understood by your terminal. You can try using chcp to set
the code page to something that works with your script.

If you are only printing it for debugging purposes you can just print therepr()
of the string which will be ascii and will come out fine in your terminal.. If you
want to write it to a html file you should encode the string with whatever
encoding (probably utf-8) you use in the html file. If you really just want your
script to be able to print unicode characters then you need to use something
other than cmd.exe (such as IDLE).


Oscar
 
O

Oscar Benjamin

I have tried to use code page 65001 and it didn't work for me even if
I did use a version of Python (possibly 3.3 alpha) that claimed to
support it.

I stand corrected. I've just checked and codepage 65001 does work in
cmd.exe (on this machine):

O:\>Q:\tools\Python33\python -c print('abc\u2013def')
Traceback (most recent call last):
File "<string>", line 1, in <module>
File "Q:\tools\Python33\lib\encodings\cp850.py", line 19, in encode
return codecs.charmap_encode(input,self.errors,encoding_map)[0]
UnicodeEncodeError: 'charmap' codec can't encode character '\u2013' in
position 3: character maps to
<undefined>

O:\>chcp 65001
Active code page: 65001

O:\>Q:\tools\Python33\python -c print('abc\u2013def')
abc-def


O:\>Q:\tools\Python33\python -c print('\u03b1')
á

It would be a lot better though if it just worked straight away
without me needing to set the code page (like the terminal in every
other OS I use).


Oscar
 
W

wxjmfauth

Le jeudi 8 novembre 2012 15:07:23 UTC+1, Oscar Benjamin a écrit :
I have tried to use code page 65001 and it didn't work for me even if
I did use a version of Python (possibly 3.3 alpha) that claimed to
support it.



I stand corrected. I've just checked and codepage 65001 does work in

cmd.exe (on this machine):



O:\>Q:\tools\Python33\python -c print('abc\u2013def')

Traceback (most recent call last):

File "<string>", line 1, in <module>

File "Q:\tools\Python33\lib\encodings\cp850.py", line 19, in encode

return codecs.charmap_encode(input,self.errors,encoding_map)[0]

UnicodeEncodeError: 'charmap' codec can't encode character '\u2013' in

position 3: character maps to

<undefined>



O:\>chcp 65001

Active code page: 65001



O:\>Q:\tools\Python33\python -c print('abc\u2013def')

abc-def





O:\>Q:\tools\Python33\python -c print('\u03b1')

α



It would be a lot better though if it just worked straight away

without me needing to set the code page (like the terminal in every

other OS I use).





Oscar

----------

It *WORKS* straight away. The problem is that
people do not wish to use unicode correctly
(eg. Mulder's example).
Read the point 1) and 4) in my previous post.

Unicode and in general the coding of the characters
have nothing to do with the os's or programming languages.

jmf
 
O

Oscar Benjamin

Le jeudi 8 novembre 2012 15:07:23 UTC+1, Oscar Benjamin a écrit :

It *WORKS* straight away. The problem is that
people do not wish to use unicode correctly
(eg. Mulder's example).
Read the point 1) and 4) in my previous post.

Unicode and in general the coding of the characters
have nothing to do with the os's or programming languages.

I don't know what you mean that it works "straight away".

The default code page on my machine is cp850.

O:\>chcp
Active code page: 850

cp850 doesn't understand utf-8. It just prints garbage:

O:\>Q:\tools\Python33\python -c "import sys;
sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))"
╬▒

Using the correct encoding doesn't help:

O:\>Q:\tools\Python33\python -c "import sys;
sys.stdout.buffer.write('\u03b1\n'.encode('cp850'))"
Traceback (most recent call last):
File "<string>", line 1, in <module>
File "Q:\tools\Python33\lib\encodings\cp850.py", line 12, in encode
return codecs.charmap_encode(input,errors,encoding_map)
UnicodeEncodeError: 'charmap' codec can't encode character '\u03b1' in
position 0: character maps to
<undefined>

O:\>Q:\tools\Python33\python -c "import sys;
sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en
coding))"
Traceback (most recent call last):
File "<string>", line 1, in <module>
File "Q:\tools\Python33\lib\encodings\cp850.py", line 12, in encode
return codecs.charmap_encode(input,errors,encoding_map)
UnicodeEncodeError: 'charmap' codec can't encode character '\u03b1' in
position 0: character maps to
<undefined>

If I want the other characters to work I need to change the code page:

O:\>chcp 65001
Active code page: 65001

O:\>Q:\tools\Python33\python -c "import sys;
sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))"
α

O:\>Q:\tools\Python33\python -c "import sys;
sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en
coding))"
α


Oscar
 
I

Ian Kelly

If I want the other characters to work I need to change the code page:

O:\>chcp 65001
Active code page: 65001

O:\>Q:\tools\Python33\python -c "import sys;
sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))"
α

O:\>Q:\tools\Python33\python -c "import sys;
sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en
coding))"
α

I find that I also need to change the font. With the default font,
printing '\u2013' gives me:

–

The only alternative font option I have in Windows XP is Lucida
Console, which at least works correctly, although it seems to be
lacking a lot of glyphs.
 
W

wxjmfauth

Le jeudi 8 novembre 2012 19:32:14 UTC+1, Oscar Benjamin a écrit :
I don't know what you mean that it works "straight away".



The default code page on my machine is cp850.



O:\>chcp

Active code page: 850



cp850 doesn't understand utf-8. It just prints garbage:



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))"

╬▒



Using the correct encoding doesn't help:



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode('cp850'))"

Traceback (most recent call last):

File "<string>", line 1, in <module>

File "Q:\tools\Python33\lib\encodings\cp850.py", line 12, in encode

return codecs.charmap_encode(input,errors,encoding_map)

UnicodeEncodeError: 'charmap' codec can't encode character '\u03b1' in

position 0: character maps to

<undefined>



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en

coding))"

Traceback (most recent call last):

File "<string>", line 1, in <module>

File "Q:\tools\Python33\lib\encodings\cp850.py", line 12, in encode

return codecs.charmap_encode(input,errors,encoding_map)

UnicodeEncodeError: 'charmap' codec can't encode character '\u03b1' in

position 0: character maps to

<undefined>



If I want the other characters to work I need to change the code page:



O:\>chcp 65001

Active code page: 65001



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))"

α



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en

coding))"

α





Oscar

You are confusing two things. The coding of the
characters and the set of the characters (glyphes/graphemes)
of a coding scheme.

It is always possible to encode safely an unicode, but
the target coding may not contain the character.

Take a look at the output of this "special" interactive
interpreter" where the host coding (sys.stdout.encoding)
can be change on the fly.

Traceback (most recent call last):
File "<eta last command>", line 1, in <module>
File "C:\Python32\lib\encodings\cp850.py", line 12, in encode
return codecs.charmap_encode(input,errors,encoding_map)
UnicodeEncodeError: 'charmap' codec can't encode character '\u2013'
'éléphant–abc需'

<<<<<<<<<<< some cheating here do to the mail system, it really looks like this.

jmf
 
W

wxjmfauth

Le jeudi 8 novembre 2012 19:32:14 UTC+1, Oscar Benjamin a écrit :
I don't know what you mean that it works "straight away".



The default code page on my machine is cp850.



O:\>chcp

Active code page: 850



cp850 doesn't understand utf-8. It just prints garbage:



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))"

╬▒



Using the correct encoding doesn't help:



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode('cp850'))"

Traceback (most recent call last):

File "<string>", line 1, in <module>

File "Q:\tools\Python33\lib\encodings\cp850.py", line 12, in encode

return codecs.charmap_encode(input,errors,encoding_map)

UnicodeEncodeError: 'charmap' codec can't encode character '\u03b1' in

position 0: character maps to

<undefined>



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en

coding))"

Traceback (most recent call last):

File "<string>", line 1, in <module>

File "Q:\tools\Python33\lib\encodings\cp850.py", line 12, in encode

return codecs.charmap_encode(input,errors,encoding_map)

UnicodeEncodeError: 'charmap' codec can't encode character '\u03b1' in

position 0: character maps to

<undefined>



If I want the other characters to work I need to change the code page:



O:\>chcp 65001

Active code page: 65001



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode('utf-8'))"

α



O:\>Q:\tools\Python33\python -c "import sys;

sys.stdout.buffer.write('\u03b1\n'.encode(sys.stdout.en

coding))"

α





Oscar

You are confusing two things. The coding of the
characters and the set of the characters (glyphes/graphemes)
of a coding scheme.

It is always possible to encode safely an unicode, but
the target coding may not contain the character.

Take a look at the output of this "special" interactive
interpreter" where the host coding (sys.stdout.encoding)
can be change on the fly.

Traceback (most recent call last):
File "<eta last command>", line 1, in <module>
File "C:\Python32\lib\encodings\cp850.py", line 12, in encode
return codecs.charmap_encode(input,errors,encoding_map)
UnicodeEncodeError: 'charmap' codec can't encode character '\u2013'
'éléphant–abc需'

<<<<<<<<<<< some cheating here do to the mail system, it really looks like this.

jmf
 
W

wxjmfauth

Le jeudi 8 novembre 2012 19:49:24 UTC+1, Ian a écrit :
I find that I also need to change the font. With the default font,

printing '\u2013' gives me:



–



The only alternative font option I have in Windows XP is Lucida

Console, which at least works correctly, although it seems to be

lacking a lot of glyphs.

--------

Font has nothing to do here.
You are "simply" wrongly encoding your "unicode".
'–'

jmf
 
W

wxjmfauth

Le jeudi 8 novembre 2012 19:49:24 UTC+1, Ian a écrit :
I find that I also need to change the font. With the default font,

printing '\u2013' gives me:



–



The only alternative font option I have in Windows XP is Lucida

Console, which at least works correctly, although it seems to be

lacking a lot of glyphs.

--------

Font has nothing to do here.
You are "simply" wrongly encoding your "unicode".
'–'

jmf
 
I

Ian Kelly

Font has nothing to do here.
You are "simply" wrongly encoding your "unicode".

'–'

No, it seriously is the font. This is what I get using the default
("Raster") font:

C:\>chcp 65001
Active code page: 65001

C:\>c:\python33\python
Python 3.3.0 (v3.3.0:bd8afb90ebf2, Sep 29 2012, 10:55:48) [MSC v.1600
32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for more information.–
4

I should note here that the characters copied and pasted do not
correspond to the glyphs actually displayed in my terminal window. In
the terminal window I actually see:

ΓÇô

If I change the font to Lucida Console and run the *exact same code*,
I get this:

C:\>chcp 65001
Active code page: 65001

C:\>c:\python33\python
Python 3.3.0 (v3.3.0:bd8afb90ebf2, Sep 29 2012, 10:55:48) [MSC v.1600
32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for more information.
'–'
–
4

Why is the font important? I have no idea. Blame Microsoft.
 
I

Ian Kelly

Why would font not matter? Unicode is the abstract definition
of all characters right? From that we map the abstract
character to a code page/set, which gives real values for an
abstract character. From that code page we then visually display
the "real value" based on the font. If that font does
not have a glyph for a specific character page (or a different
glyph) then that is a problem and not related encoding.

Usually though when the font is missing a glyph for a Unicode
character, you just get a missing glyph symbol, such as an empty
rectangle. For some reason when using the default font, cmd seemingly
ignores the active code page, skips decoding the characters, and tries
to print the individual bytes as if using code page 437.
 
O

Oscar Benjamin

Le jeudi 8 novembre 2012 19:49:24 UTC+1, Ian a écrit :

Font has nothing to do here.
You are "simply" wrongly encoding your "unicode".

'–'

You have correctly identified that the displayed characters are the
result of accidentally interpreting utf-8 bytes as if they were cp1252
or similar. However, it is not Ian or Python that is confusing the
encoding. It is cmd.exe that is confusing the encoding in a
font-dependent way. I also had to change the font as Ian describes
though I did it some time ago and forgot to mention it here.

jmf, can you please trim the text you quote removing the parts you are
not responding to and then any remaining blank lines that were
inserted by your reader/editor?


Oscar
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Similar Threads

Thinking Unicode 0
Unicode 2
split lines from stdin into a list of unicode strings 0
Convert unicode escape sequences to unicode in a file 1
unicode compare errors 3
unicode 7
Ascii to Unicode. 16
Unicode error 19

Members online

Forum statistics

Threads
473,962
Messages
2,570,134
Members
46,690
Latest member
MacGyver

Latest Threads

Top