八进制字符串文字和八进制命令行参数

2024-04-20 03:19:14 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个八进制字符串"\334\n\226"\n不是八进制,因为它有一个可打印的ASCII表示)。我想在字节数组中编码它,所以我想转换"\334\n\226"->;[\334, \n, \226]->;[220, 10, 150]。我想写以下代码:

octal_string = "\334\n\226"
encoded_string = octal_string.encode()
for b in encoded_string:
  print(b)

这将输出:

195 156 10 194 150

另外,我想将此字符串作为命令行参数传递给脚本,因此如果我编写脚本:

import sys

octal_string = sys.argv[1]
encoded_string = octal_string.encode()
for b in encoded_string:
  print(b)

然后我跑:

> python3 myscript.py \334\n\226

我得到:

51 51 52 110 50 50 54

我该怎么做?你知道吗


Tags: 字符串ingt脚本forstring字节sys
1条回答
网友
1楼 · 发布于 2024-04-20 03:19:14

您可以将regex或以下代码与list comprehension、split()和int()方法一起使用:

import sys

if len(sys.argv) == 2:

    s=sys.argv[1]
    print(s)
    print(s.split("\\"))
    rslt=[ 10 if e=="n" else int(e,8) for e in s.split("\\") if e ]
    print(rslt)

引号很重要:

$ python3 myscript.py "\334\n\226"
\334\n\226
['', '334', 'n', '226']
[220, 10, 150]

编辑: 在Python3中,此代码起作用:

b= bytes(sys.argv[1],"utf8")
print(b)
#rslt= [ ord(c) for c in str(b,"unicode-escape") ]
rslt= [ ord(c) for c in b.decode("unicode-escape") ]
print(rslt) 

b'\\334\\ne\\226'
[220, 10, 101, 150]

编辑2:

import ast

s= ast.literal_eval("'"+sys.argv[1]+"'")  # It interprets the escape sequences,too.
print( [ord(c) for c in s ] )

[220, 10, 101, 150]

相关问题 更多 >