2006-11-22 23:08:13

先頭から2文字ずつ取る

テーマ:Python
16進ダンプデータを変換するスクリプトを書いていて、
色々邪魔な文字を削除した後の任意の長さの16進数データを得たとする。
0123456789abcdef

これから、
[0x01,0x23,0x45,0x67,0x89,0xab,0xcd,0xef]

というリストを得たい。
そんなとき書いたスクリプトがこれでした。

def bytelist(s):
result = []
for idx in range(0,len(s),2):
result.append(int('0x'+s[idx:idx+2],16))
return result

for x in bytelist('0123456789abcdef'):
print "%s " % hex(x),

しかし、もっとエレガントに書けないかとおもって、工夫したのがこれ。

def bytelist(s):
result = []
for a,b in zip(s[0::2],s[1::2]):
result.append(int('0x%s%s' % (a,b),16))
return result

len()やidxなどの変数や概念が無くなった所がPythonっぽくっていいと思ったのだが、
これを動かそうとしていた環境がPython2.2しか入っていなくて、結局元に戻した。
AD
いいね!した人  |  コメント(0)  |  リブログ(0)

mar-amebloさんの読者になろう

ブログの更新情報が受け取れて、アクセスが簡単になります

コメント

[コメントをする]

コメント投稿

AD

ブログをはじめる

たくさんの芸能人・有名人が
書いているAmebaブログを
無料で簡単にはじめることができます。

公式トップブロガーへ応募

多くの方にご紹介したいブログを
執筆する方を「公式トップブロガー」
として認定しております。

芸能人・有名人ブログを開設

Amebaブログでは、芸能人・有名人ブログを
ご希望される著名人の方/事務所様を
随時募集しております。