11

您可以通过这种方式从字符串创建原始字符串:

test_file=open(r'c:\Python27\test.txt','r')

如何从字符串变量创建原始变量,例如

path = 'c:\Python27\test.txt'

test_file=open(rpath,'r')

因为我有一个文件路径:

file_path = "C:\Users\b_zz\Desktop\my_file"

当我做:

data_list = open(os.path.expandvars(file_path),"r").readlines()

我得到:

Traceback (most recent call last):
  File "<pyshell#32>", line 1, in <module>
    scheduled_data_list = open(os.path.expandvars(file_path),"r").readlines()
IOError: [Errno 22] invalid mode ('r') or filename: 'C:\\Users\x08_zz\\Desktop\\my_file'
4

3 回答 3

9

一旦在过程中创建了字符串,就没有“原始字符串”这样的东西。指定字符串的""r""方式仅存在于源代码本身中。

这意味着"\x01"将创建一个由一个字节组成的字符串0x01,但r"\x01"将创建一个由 4 个字节组成的字符串'0x5c', '0x78', '0x30', '0x31'。(假设我们正在谈论 python 2 并暂时忽略编码)。

您在评论中提到您正在从用户那里获取字符串(gui 或控制台输入在这里的工作方式相同) - 在这种情况下,将不会处理字符串字符转义,因此您无需做任何事情。您可以像这样轻松地检查它(或任何 Windows 等效项,我只说 *nix):

% cat > test <<EOF                                             
heredoc> \x41
heredoc> EOF
% < test python -c "import sys; print sys.stdin.read()"
\x41
于 2014-02-06T17:27:26.127 回答
6

我将字符串转换为原始字符串的解决方案(仅适用于以下序列: '\a', \b', '\f', '\n', '\r', '\t', '\v' 。列表所有转义序列都在这里):

def str_to_raw(s):
    raw_map = {8:r'\b', 7:r'\a', 12:r'\f', 10:r'\n', 13:r'\r', 9:r'\t', 11:r'\v'}
    return r''.join(i if ord(i) > 32 else raw_map.get(ord(i), i) for i in s)

演示:

>>> file_path = "C:\Users\b_zz\Desktop\fy_file"
>>> file_path
'C:\\Users\x08_zz\\Desktop\x0cy_file'
>>> str_to_raw(file_path)
'C:\\Users\\b_zz\\Desktop\\fy_file'
于 2014-02-06T14:35:35.337 回答
0

ndpu 的解决方案对我有用。

我无法抗拒增强它的诱惑(使其与古老的 Python 2 版本兼容并希望加快它的速度):

_dRawMap = {8:r'\b', 7:r'\a', 12:r'\f', 10:r'\n', 13:r'\r', 9:r'\t', 11:r'\v'}

def getRawGotStr(s):
    #
    return r''.join( [ _dRawMap.get( ord(c), c ) for c in s ] )

我做了一个仔细的计时试验,结果发现ndpu的原始代码要快一点。列表推导很快,但生成器表达式更快。

于 2018-01-28T20:03:19.400 回答