Python 常见问题

1. 'gbk' codec can't encode character '\xa0',类似这样的编码出错问题

一般是因为用控制台执行时,控制台本身的编码无法输出该字符,因此可以通过replace来把这个编码给替换掉,比如对上面这种情况就:

str1.replace('\xa0', '')
2. 网站的res.text是乱码

可以尝试获取content的字节流然后解码,比如:print(res.content.decode('utf-8'))
或者在前面加一句:res.encoding = 'utf-8'

3. 复制的python代码缩进有误

pycharm中按Alt+Enter,然后选择自动对齐

4.希望运行程序不出现命令行

后缀改成.pyw

5.读取utf-8文件,出现类似:invalid literal for int() with base 10: '\ufeff1'的问题

两种解决方法:
(1)将文件编码改为:utf-8设置为无BOM格式
(2)在python读取文件时将编码设置为:utf-8-sig

6..py打包成.exe

(1)pip install pyinstaller
(2)在当前文件夹下打开cmd,输入:pyinstaller -F xxx.py即可
(3)如果多个文件,就把要执行的文件放前面,并排输入,比如有a.py和b.py,其中b.py是作为导入用的,则:pyinstaller -F a.py b.py
(4)如果希望转成的exe文件不要命令行窗口,可以参考:https://www.aliyun.com/jiaocheng/523869.html

更多参数配置参考:https://blog.csdn.net/chenzhanhai/article/details/85334919

7.程序执行效率慢

通过profile.run('函数名()')来看函数执行效率

import profile
profile.run('function()')

还可以参考:https://blog.csdn.net/weixin_40539892/article/details/79087237

8.unindent does not match any outer indentation level

把所有的缩进替换成4个空格即可

9.str类型的字符明明内容就是字典格式,却无法直接用dict()转成字典

eval()函数,举例:

>>> a
"{'a':1, 'b':2}"
>>> type(a)

>>> dict(a)
Traceback (most recent call last):
  File "", line 1, in 
    dict(a)
ValueError: dictionary update sequence element #0 has length 1; 2 is required
>>> eval(a)
{'b': 2, 'a': 1}
>>> type(eval(a))

10.os.system('pause')修改“按任意键继续...”的文字

可以先输出想要的文字,然后通过重定向将自带输出内容给隐藏,举例:

print("按任意键退出...")
os.system('pause > nul')
exit()
11.匹配中文

因为中文字符范围为:\u4e00~\u9fff,所以可以用下面正则匹配:

[\u4e00-\u9fff]
12.权限不够

管理员身份运行:https://blog.csdn.net/qq_17550379/article/details/79006655
注册表添加权限:https://blog.csdn.net/qq_17550379/article/details/79006718

13.分析函数和调用函数

比如下面这两个对比:

def aaa():
    print(111)
    return "aaa"

x = [aaa, aaa()]
print(x)

结果为:
111
[, 'aaa']

可以发现列表x中第一个值是函数对象,第二个是执行函数后返回的结果

14.'\u'开头字符的拼凑和输出

有时候想要自己输出\u的字符,比如下面的:

>>> '\u1234'
'ሴ'

那么直接完整的定义是可以的,但如果想要自己拼凑,比如下面这样:

>>> '\u' + '1234'
SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 0-1: truncated \uXXXX escape

结果发现报错了,说是不能直接拼凑\u开头的,于是在\前加个\进行转义,如下:

>>> '\\u' + '1234'
'\\u1234'
>>> print('\\u' + '1234')
\u1234

结果发现输出的就不是我们要的字符,而是转义后的单纯的字符串,所以参考了下面的链接,发现可以用encode+decode来解决,举例:

>>> ('\\u' + '1234').encode('utf-8').decode('unicode_escape')
'ሴ'

在然后我们就可以根据这个来解决一些实际的问题了,比如windows控制台由于一些编码符号不能输出,导致程序报错,比如下面这个程序:

try:
    print('这个一个控制台无法打印的符号:♈')
    input()
except Exception as e:
    print(e)
    input()

控制台打开结果:
'gbk' codec can't encode character '\u2648' in position 0: illegal multibyte sequence

于是我们就可以通过正则匹配到这个符号的字符串,然后替换掉,这里直接贴代码:

import re

try:
    str1 = '这个一个控制台无法打印的符号:♈'
    print(str1)
    input()
except UnicodeEncodeError as e:
    x = ('\\' + re.findall('(u.+?)\'', str(e))[0]).encode('utf-8').decode('unicode_escape')
    print(str1.replace(x, '【某符号】'))
    input()

结果:
这个一个控制台无法打印的符号:【某符号】

参考:
https://www.cnblogs.com/hahaxzy9500/p/7685955.html

15.linux下pip安装

https://www.cnblogs.com/technologylife/p/5870576.html

16.python2代码转python3

如果有将python2的代码转成python3的代码需求,可以使用python自带的2to3.py工具,详细参考:
https://blog.csdn.net/ly021499/article/details/81735813

你可能感兴趣的:(Python 常见问题)