gpt4 book ai didi

python - python如何测试从数据库中提取的一些纯文本中的二进制数据

转载 作者:行者123 更新时间:2023-11-29 09:07:38 25 4
gpt4 key购买 nike

我必须从mysql数据库中提取一些产品信息,然后构造一个SOAP请求并使用 python 的 suds 库发送此 SOAP向远程服务器发出请求。

但有些信息提取是结合了二进制数据和文本数据,例如:

...
Some plain data
...
Content-Type: image/pjpeg

? JFIF H H  C


 C
 P P   E !1AQa "q?#2脑$4BCR倯ご?3TVfrs枴贬  - !1A"2QR亼Ba毖q? ? 鮊€
( ?€
( ?€
釱Whf颲[e?喸媼q屧ㄠ蚀厲蹳ZIO痙(r5?-i擯栧剗矹?尴?蝓玁帰XZ鞭#崛攳┸蹵X僦?攅Z@?らM;X藙?N蹮垀s@jQ?Z徸林炑M~?麒]H=颦C胝_р}"?Gixqz坽徸玨?O?Q+谍?w鬪??-囯礥?а|乛聚Zyt>?`[~跲桫?騽D曐縅CmN=?shOU+湫锏竩&6げ?铚扺d)mn?c?X?6RmQ JJ?7繴*v>.捈鉵基d?堌疻熼G肗裪囅w騲癔R?qW鑪陭瞘.C窄贇CkyV瀷1? 柚%W}}?Yz僫芐D嫆1鬊懜赈篽效lq蒟H棯]y|G.;硅憖Ew??栧$?=e菚鏪Rbj?枝}爲釼Z3FE<尒n%C蓎??樋>`I 顝y∥+pP敐慗岻゛\硳诮湣]~??xΔ诩[_?叴b嫜?yz*?=ψk?猝"%Ak?撍滷秠BR?-铈b礖?蟷y[)厌麓4,怈
窧q觏?_ N獛擒F杍q凞画Q襃@镛P$讄k\鏁祘譟㎎*V>W??鵔M嫯q寓y焊閔C杔栽?+鹕瑟qbs:z氱^PJ聣?汜ZU"ス嘔+輔€8楺<夻Uゎ顓瞚?氅豴<]P銨c? +K6]┓gr杺 蝫?VJ能?陭欹殡J倢gS扚?娭酧??gw?膙y矼j折B礕殯
繅捁%撽蛵震挔撲y?3鑪澳N?Ec~涰巽j慭搆锥▓IP?)┤燎鐠懴 €H9瘾F毖l氾+岎6o?殎託炗y尬n??8??黬?4Qbń覦;縢?兟HRONd *紂蚽娖t猦?^?2
庴E$x 譴q箘瘃J檐H筶鷆[?8 ?9颢*髟揤v緜魸擭槧?%msV嬖z瘨摉擀F摫鞍s犮殩H4s咸?S蓉扷濅? V?昋c?u婆SG撙???{臘亞攕曳<\K? D]+#瓃kgw犤?.?惨邔蹓#p(巂s?瘑蜲Q?傻鑟6ce?敟)?9嶔?測誗?yfvp謒NnbmB3齑栘v>RR=拏H'焴j壎e鎨洘?窑??MH单;5?T1倧o)锐认J?QY&7?橥%诤授b?氭\堫轁q)荖no弎閂?添頶5E敌?U瞿??雛柖Q??Ps?冇9'=)J殅朥k%鈌l疆$q}?い$袋蜕~跏綺衄qU玉矰潱v硻e鷵?薭?<爗树q熣?I;ぞ_鬿埗d.握莰俜6渺^貀No-乾R?r\芷<A稙鋆j璲吡累Y错$F梱?镫[猄k\﹋JrRp悇?救
...
end of binary data.

我不知道这些数据是如何插入到mysql中的,但是我必须检测这种类型的数据,并将这个二进制数据替换为字符串EEEEE ,否则肥皂水会引发异常。

谁能告诉我如何测试这种类型的数据?

提前致谢。

最佳答案

混合文本和二进制?!听起来很糟糕...

但是,如果所有数据均采用您在示例中呈现的格式(即使用 Content-type 声明),您可以执行以下操作:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

data = '''Some plain data!Content-Type: image/pjpeg ? JFIF H H  C  C 
P P   E !1AQa "q?#2脑$4BCR倯ご?3TVfrs枴贬  - 釱W
hf颲[e?喸媼q屧ㄠ蚀厲蹳ZIO痙(r5?-i擯栧剗矹?尴?蝓玁帰XZ鞭#崛攳┸蹵X僦?攅Z@?らM
;X藙?N蹮垀s@jQ?Z徸林炑M~?麒]H=颦C胝_р}"?Gixqz坽徸玨?O?Q+谍?w鬪??'''
tdata = '''This has no binary in it'''

def filter_data(blob):
mixed = blob.find('Content-Type:')
if mixed != -1: # -1 ==> not found
return blob[:mixed] + 'EEEEE'
return blob

print filter_data(data)
print filter_data(tdata)

如果二进制数据前面没有添加 Content-Type 声明,我不确定是否有100% 可靠的方法来区分文本和二进制(一个字节)二进制文件中的字符可以解码为一些有意义的字符),但您至少可以通过过滤有效字符池来改善这种情况。

例如,假设所有有效文本都是字母数字 A-Z、a-z 和 0-1 加空格字符:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

data = '''Some plain data脑$4BCR倯ご?3TVfrs枴贬  - 釱W hf颲[e?喸媼q屧ㄠ蚀厲蹳
ZIO痙(r5?-i擯栧剗矹?尴?蝓玁帰XZ鞭#崛攳┸蹵X僦?攅Z@?らM;X藙?N蹮垀s@jQ?Z徸
林炑M~?麒]H=颦C胝_р}"?Gixqz坽徸玨?O?Q+谍?w鬪??'''
tdata = '''This has no binary in it'''
bdata = '''炑M~?麒]H=颦C胝'''

pool = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789 '

def filter_data(blob):
last_good_one = None
for i, c in enumerate(blob):
if c in pool:
last_good_one = i
else:
break
if last_good_one == None:
raise BaseException('Only binary data!')
return blob[:last_good_one+1]

print filter_data(data)
print filter_data(tdata)
print filter_data(bdata)

呵呵!

关于python - python如何测试从数据库中提取的一些纯文本中的二进制数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6593504/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com