Hello,
I am trying to xor the byte representation of every char in a string with
its predecessor. But I don't know how to convert a char into its byte
representation. This is to calculate the nmea checksum for gps data.
e.g. everything between $ and * needs to be xor:
$GPGSV,3,1,10,06,79,187,39,30,59,098,40,25,51,287, 00,05,25,103,44*
to get the checksum.
Thank you for you help.
Phil 7 40227
ord(c) gives you decimal representation of a character.
-Larry Bates
Philipp H. Mohr wrote: Hello,
I am trying to xor the byte representation of every char in a string with its predecessor. But I don't know how to convert a char into its byte representation. This is to calculate the nmea checksum for gps data.
e.g. everything between $ and * needs to be xor: $GPGSV,3,1,10,06,79,187,39,30,59,098,40,25,51,287, 00,05,25,103,44* to get the checksum.
Thank you for you help.
Phil
Philipp H. Mohr wrote: I am trying to xor the byte representation of every char in a string with its predecessor. But I don't know how to convert a char into its byte representation.
ord('a') == 97; chr(97) == 'a'; "ord" gives you the value of the byte.
e.g. everything between $ and * needs to be xor: $GPGSV,3,1,10,06,79,187,39,30,59,098,40,25,51,287, 00,05,25,103,44* to get the checksum.
Probably you want a byte-array here, rather than going char-by-char.
Try:
import array
base = ('$GPGSV,3,1,10,06,79,187,39,30,59,098,'
'40,25,51,287,00,05,25,103,44*')
bytes = array.array('b', base[1 : -1])
for i in reversed(range(len(bytes))):
bytes[i] ^= bytes[i-1]
result = bytes.tostring()
--Scott David Daniels sc***********@acm.org
On 2005-10-10, Larry Bates <la*********@websafe.com> wrote: I am trying to xor the byte representation of every char in a string with its predecessor. But I don't know how to convert a char into its byte representation. This is to calculate the nmea checksum for gps data.
ord(c) gives you decimal representation of a character.
While ord(c) is what the OP needs, it doesn't give a decimal
represention -- which I guess would be a string like "65" for
the ASCII characer "A". What ord() gives you is an integer
object with the value of the character [which the hardware
stores in binary on all of the platforms I'm aware of].
--
Grant Edwards grante Yow! Hmmm... A hash-singer
at and a cross-eyed guy were
visi.com SLEEPING on a deserted
island, when...
Scott David Daniels <sc***********@acm.org> wrote in
news:43********@nntp0.pdx.net: Philipp H. Mohr wrote: I am trying to xor the byte representation of every char in a string with its predecessor. But I don't know how to convert a char into its byte representation. ord('a') == 97; chr(97) == 'a'; "ord" gives you the value of the byte.
e.g. everything between $ and * needs to be xor: $GPGSV,3,1,10,06,79,187,39,30,59,098,40,25,51,287, 00,05,25, 103,44* to get the checksum.
Probably you want a byte-array here, rather than going char-by-char. Try: import array base = ('$GPGSV,3,1,10,06,79,187,39,30,59,098,' '40,25,51,287,00,05,25,103,44*') bytes = array.array('b', base[1 : -1]) for i in reversed(range(len(bytes))): bytes[i] ^= bytes[i-1] result = bytes.tostring()
--Scott David Daniels sc***********@acm.org
What is the byte representation of 287?
--
rzed
Scott David Daniels wrote: Philipp H. Mohr wrote: I am trying to xor the byte representation of every char in a string with its predecessor. But I don't know how to convert a char into its byte representation. ord('a') == 97; chr(97) == 'a'; "ord" gives you the value of the byte.
e.g. everything between $ and * needs to be xor: $GPGSV,3,1,10,06,79,187,39,30,59,098,40,25,51,287, 00,05,25,103,44* to get the checksum.
Probably you want a byte-array here, rather than going char-by-char. Try: import array base = ('$GPGSV,3,1,10,06,79,187,39,30,59,098,' '40,25,51,287,00,05,25,103,44*') bytes = array.array('b', base[1 : -1]) for i in reversed(range(len(bytes))): bytes[i] ^= bytes[i-1] result = bytes.tostring()
Seems like the OP doesn't need what he asked for. The simpler
def checksum(s):
assert s[0] == "$"
assert s[-1] == "*"
result = 0
for c in s[1:-1]:
result ^= ord(c)
return result
should do.
Peter
I've always read it written that the number that is returned by
ord(c) is the "decimal" (not hex, not octal) representation of
the ASCII/UNICODE character that is stored in memory location
pointed to by variable c. While the result is an integer (as
it couldn't really be anything else), I believe that most
character charts list the number that ord() returns as the
"decimal representation" of that character (as they normally
also show the octal and hex values as well).
Probably an "old school" answer on my part.
-Larry Bates
Grant Edwards wrote: On 2005-10-10, Larry Bates <la*********@websafe.com> wrote:
I am trying to xor the byte representation of every char in a string with its predecessor. But I don't know how to convert a char into its byte representation. This is to calculate the nmea checksum for gps data.
ord(c) gives you decimal representation of a character.
While ord(c) is what the OP needs, it doesn't give a decimal represention -- which I guess would be a string like "65" for the ASCII characer "A". What ord() gives you is an integer object with the value of the character [which the hardware stores in binary on all of the platforms I'm aware of].
[Format recovered from top posting.]
Larry Bates <la*********@websafe.com> writes: Grant Edwards wrote: On 2005-10-10, Larry Bates <la*********@websafe.com> wrote:I am trying to xor the byte representation of every char in a string with its predecessor. But I don't know how to convert a char into its byte representation. This is to calculate the nmea checksum for gps data.ord(c) gives you decimal representation of a character.
While ord(c) is what the OP needs, it doesn't give a decimal represention -- which I guess would be a string like "65" for the ASCII characer "A". What ord() gives you is an integer object with the value of the character [which the hardware stores in binary on all of the platforms I'm aware of].
I've always read it written that the number that is returned by ord(c) is the "decimal" (not hex, not octal) representation of the ASCII/UNICODE character that is stored in memory location pointed to by variable c. While the result is an integer (as it couldn't really be anything else), I believe that most character charts list the number that ord() returns as the "decimal representation" of that character (as they normally also show the octal and hex values as well).
The value returned by ord is a *number*. That number has a decimal
representation. It also has a hex representation and an octal
representation. These are all strings, and they all represent the same
number. You can't print a number - you can only print characters. So
Python (indeed, most languages) translate the number into a string of
characters that represent the number, using the decimal
representation. You can use the hex and oct builtins to ask for the
hex and octal representations of that number and print those strings
if you want.
Probably an "old school" answer on my part.
The decimal representation of ' ' is '32'. Python doesn't think that
that's what ord(' ') returns: ord(' ') == '32'
False
So I'd say it was "wrong" rather than old school.
On the other hand, if you check ord(' ') against numbers, it doeesn't
care what representation you use, so long as they represent the same
number:
ord(' ') == 0x20
True ord(' ') == 040
True ord(' ') == 32
True
Of course you can't read a number any more than you can write one, so
Python kindly translates strings representing numbers into numbers
when itt reads them. This process is often referred to as "reading a
number", but what's actually read is characters.
<mike
--
Mike Meyer <mw*@mired.org> http://www.mired.org/home/mwm/
Independent WWW/Perforce/FreeBSD/Unix consultant, email for more information. This discussion thread is closed Replies have been disabled for this discussion. Similar topics
19 posts
views
Thread by jeff |
last post: by
|
6 posts
views
Thread by Ricardo Quintanilla |
last post: by
|
15 posts
views
Thread by Kueishiong Tu |
last post: by
|
7 posts
views
Thread by MilanB |
last post: by
|
13 posts
views
Thread by NISARG |
last post: by
|
1 post
views
Thread by Elioth |
last post: by
|
8 posts
views
Thread by Serge BRIC |
last post: by
| | | | | | | | | | | | |