-----使用技术手段解决问题,坚信注重每一个细节,把熟悉的做到一种极致,一定会有创新出现。-----

python input()键盘输入8583报文带有\x单反斜杠自动转义问题解决办法

  用input()输入的字符串是8385报文比如:\x30\x30\x30\x30。。。,但是输入后,代码把8583报文字符串中多加了一个\,类似\\x30。

  但是我把input()代码注释掉,把8583报文在变量中写死,就没有这个问题,我想应该是编码问题造成的。

  input输入和变量固定,难道还有什么不一样吗?

  代码如下:

  输入的单反斜杠,被系统自动转义双反斜杠\\x,代码中增加了依据判断:
1 if "\\x" in input_a1:

  在input()键盘输入时,增加decode("unicode_escape")解决了问题。

  代码如下:

 1 #coding:utf-8
 2 
 3 #固定8583报文16进制数据
 4 a = "\x31\x31\x39\x39\x30\x36\x30\x30\x30\x32\x30\x30"
 5 print(type(a))
 6 print(a)
 7 b = str(a)
 8 print("变量-->%s"%b)
 9 
10 
11 #通过键盘复制的8583报文16进制数据
12 #\x31\x31\x39\x39\x30\x36\x30\x30\x30\x32\x30\x30
13 input_a = raw_input("输入1—>:").decode("unicode_escape")
14 if "\\x" in input_a:
15     print("输入的单反斜杠,被系统自动转义双反斜杠\\x")
16 else :
17     print("使用unicode_escape存储内存值方法,输入的8583报文单反斜杠没有被转义")
18     print(type(input_a))
19     b = str(input_a)
20     print("键盘-->%s"%b)
21     
22 #查问题
23 input_a1 = raw_input("输入2—>:")
24 if "\\x" in input_a1:
25     print("输入的单反斜杠,被系统自动转义双反斜杠\\x")
26 else :
27     print(type(input_a))
28     b = str(input_a)
29     print("键盘-->%s"%b)

  百度了一些资料,我们数据字符串通常都是str、unicode类型,基本上都是采用直接存储的的方式,还有一种存储方式是按字符串的内存编码值进行存储,它在读取字符串的时候再反转回来。

1 >>> u'中文测试'.encode('unicode-escape')
2 '\\u4e2d\\u6587\\u6d4b\\u8bd5'
3 
4 >>> '\\u4e2d\\u6587\\u6d4b\\u8bd5'.decode('unicode-escape')
5 u'\u4e2d\u6587\u6d4b\u8bd5'

 

posted @ 2018-02-03 22:01  ZhuQue  阅读(1377)  评论(0编辑  收藏  举报
多年性能测试、测试管理经验,专注银行、支付、电商行业,倾向于性能、安全、 监控、调优、模型、管理等方向的研究。
使用技术手段解决问题,坚信注重每一个细节,把熟悉的做到一种极致,一定会有创新出现。