python和二进制数组

网上查了很多,都是用了struct来进行打包和解包,内容请自己行google,可是并不是我要的结果,我不过是要把一段字符串直接转化成byte[],没有那么严格的每一个位置进行定义的需求,搜来搜去,发现python2.6已经直接支持二进制数组:

由于还不是非常明白,测试如下

>>> s1="中华人民共和国"

>>> s1

'\xd6\xd0\xbb\xaa\xc8\xcb\xc3\xf1\xb9\xb2\xba\xcd\xb9\xfa'

>>> list(s1)

['\xd6', '\xd0', '\xbb', '\xaa', '\xc8', '\xcb', '\xc3', '\xf1', '\xb9', '\xb2', '\xba', '\xcd', '\xb9', '\xfa']

>>> s2=b"中华人民共和国"

>>> s2

'\xd6\xd0\xbb\xaa\xc8\xcb\xc3\xf1\xb9\xb2\xba\xcd\xb9\xfa'

>>> list(s2)

['\xd6', '\xd0', '\xbb', '\xaa', '\xc8', '\xcb', '\xc3', '\xf1', '\xb9', '\xb2', '\xba', '\xcd', '\xb9', '\xfa']

>>> s3=u"中华人民共和国"

>>> s3

u'\xd6\xd0\xbb\xaa\xc8\xcb\xc3\xf1\xb9\xb2\xba\xcd\xb9\xfa'

>>> list(s3)

[u'\xd6', u'\xd0', u'\xbb', u'\xaa', u'\xc8', u'\xcb', u'\xc3', u'\xf1', u'\xb9', u'\xb2', u'\xba', u'\xcd', u'\xb9', u'\xfa']

>>> s4=bytearray("中华人民共和国")

>>> s4

bytearray(b'\xd6\xd0\xbb\xaa\xc8\xcb\xc3\xf1\xb9\xb2\xba\xcd\xb9\xfa')

>>> list(s4)

[214, 208, 187, 170, 200, 203, 195, 241, 185, 178, 186, 205, 185, 250]

>>> #演示把byte变为sbyte

>>> s5=[i if i<128 else i-256 for i in s4]

>>> s5

[-42, -48, -69, -86, -56, -53, -61, -15, -71, -78, -70, -51, -71, -6]

>>> 

>>> type(s1)

<type 'str'>

>>> type(s2)

<type 'str'>

>>> type(s3)

<type 'unicode'>

>>> type(s4)

<type 'bytearray'>

>>> type(s5)

<type 'list'>

>>> 

小技巧,上面的示例中,把byte转为sbyte用了列表映射和“三元表达式”,当然python中是没有三元表达式的,所以我用的语法是if else,

当然灵活地用and-or组合,同样可以达到效果:

s5=[i<128 and i-256 or i for i in s4]



#此处有一个bug,即i为零和256时会出错,鉴于256不会出现,那么就处理0值:

s5=[i<128 and i!=0 and i-256 or i for i in s4]

当然这需要对and-or系统语法有着非常深入的了解了

你可能感兴趣的:(python)