網上查了很多,都是用了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"中華人民共和國">>> s3u'\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("中華人民共和國")>>> s4bytearray(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系統文法有著非常深入的瞭解了