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)
<class 'str'>
>>> dict(a)
Traceback (most recent call last):
File "<pyshell#3>", line 1, in <module>
dict(a)
ValueError: dictionary update sequence element #0 has length 1; 2 is required
>>> eval(a)
{'b': 2, 'a': 1}
>>> type(eval(a))
<class 'dict'>
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
[<function aaa at 0x0143D420>, '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