我目前正在使用python的timeit内置库来获取小代码片段的执行时间。
我的代码:-
import timeit
print(timeit.timeit(setup='env = "C:\\Users\\MyName"', stmt='a = f"{env} is my username"'))上面的代码在执行时会生成Unicode Escape Error。
错误堆栈:-
Traceback (most recent call last):
File "D:/Users/apple/vul.py", line 3, in <module>
print(timeit.timeit(setup='env = "C:\\Users\\MyName"', stmt='a = f"{env} is my username"'))
File "C:\Users\apple\AppData\Local\Programs\Python\Python37-32\lib\timeit.py", line 232, in timeit
return Timer(stmt, setup, timer, globals).timeit(number)
File "C:\Users\apple\AppData\Local\Programs\Python\Python37-32\lib\timeit.py", line 109, in __init__
compile(setup, dummy_src_name, "exec")
File "<timeit-src>", line 1
SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape当字符串中存在转义序列解释(通过单个\后跟一个字符)时,通常会产生此错误。但在我的例子中,我已经使用\\(双反斜杠)转义了字符串中的反斜杠。
发布于 2019-06-25 06:22:58
您已经正确地诊断了问题:字符串中的转义序列解释。
您已经避开了反斜杠一次。这意味着timeit在其setup参数中接收以下字符串:'env = "C:\Users\MyName"',每次出现时都有一个\。当它执行该字符串时,它会找到它认为有问题的Unicode序列:'\Users'。
它很容易修复:
print(timeit.timeit(setup=r'env = "C:\\Users\\MyName"', stmt='a = f"{env} is my username"'))https://stackoverflow.com/questions/56744027
复制相似问题