1、(unicode error) ‘unicodeescape’ codec can’t decode bytes in position 2-3: truncated \UXXXXXXXX escap错误,如:
>>>import sys
>>>sys.path.append("c:\users\administrator\desktop\py\san.py")
解决办法:在Python中\是转义符,\u表示其后是UNICODE编码,因此\user在这里会报错,在字符串前面加个r表示就可以了,即:
>>>import sys
>>>sys.path.append(r"c:\users\administrator\desktop\py\san.py")
2、用urllib.request.urlopen()打开带有中文的网址时会报错
解决办法:先用urllib.parse.quote()对链接中的中文进行处理,如下:
import urllib.request
import urllib.parse
url = "http://www.baidu.com/s?wd=" +urllib.parse.quote("中国")
resp = urllib.request.urlopen(url)
print(resp.read().decode('utf-8'))
注:只对其中的中文进行处理,如果对整个网址进行quote处理也会报错。
3、报错:OSError: [Errno 22] Invalid argument: 'C:/Users/Administrator/Desktop/py/newpy/父亲节 | 致爱你最深 却又从不表达的人.txt’
解决办法:
a、路径转义:路径前加r即可;
b、文件名错误:文件名不能包含英文中的下列符号 \ / : * ? " < > |
4、在写入TXT文件时,某些页面总是报UnicodeEncodeError: ‘gbk’ codec can’t encode character ‘\u2022’ in position 172: illegal multibyte sequence错误:
解决办法:在f = open(‘test.txt’, ‘w’, encoding=‘utf-8’) 里加上encoding='utf-8’参数。
原因:网页及python的编码都是utf-8,在写进txt时,Windows默认转码成gbk,遇到某些gbk不支持的字符就会报错。在打开文件时就声明编码方式为utf-8能避免这个错误。
5、sublime text3中用sublimeREPL打印大文件会很慢甚至卡死的解决办法:
解决办法:使用Ctrl+B编译运行(代码中不能包含input())即可,如果代码中含input()会报错EOFError: EOF when reading a line。
6、Ctrl+B运行如出现[decode error - output not utf-8]问题:
解决办法:给电脑添加环境变量,在系统变量中填写变量名PYTHONIOENCODING和变量值utf-8,如是其他编码问题,则值换成其他编码即可。
添加环境变量(win7):右键计算机 -> 属性 -> 右侧高级系统设置 -> 环境变量 -> 系统变量(S) -> 新建 -> 输入变量名和变量值 -> 多次确定即可。
7、IncompleteRead(25856 bytes read, 19 more expected)错误:
原因:这个异常表示希望从HTTP body 中读取A 字节,但实际能够读取的字节数小于A个字节。
HTTP Response 的Header 大致如下:
{'connection': 'keep-alive', 'content-type': 'application/json', 'content-length': '44668', 'content-encoding': 'gzip'}
可以判断Response body完整传输(safe transport)的要素是 content-length,也就是说实际读到的body体的长度小于content_length。
捕获异常及处理:
for li in lie:
try:
li_code.append(get_html(li)) #获取详情页面code
except Exception as e:
print(e)
#print(e.partial.decode('utf-8')) #捕获异常原代码
li_code.append(e.partial.decode('utf-8')) #将捕获的异常页面代码添加到列表中(此处根据实际情况更改)
continue #继续for循环
8、TabError: inconsistent use of tabs and spaces in indentation错误:
原因:是看似空格实则没有空格引起的,修改了很多遍,发现还是空格失败。
解决办法:复制前面正常的空格到提示代码前就好了。
9、openpyxl模块border边框缺失:
引入fix_border.py文件,以下是其完整代码:
#!/usr/bin/env python
#-*-conding=utf-8-*-
from itertools import product
import types
import openpyxl
from openpyxl.utils import get_column_letter
from openpyxl import worksheet
from openpyxl.utils import range_boundaries
from itertools import product
import regex as re #此为第三方模块,需pip install regex安装,regex基本兼容re模块
def patch_worksheet():
"""
这monkeypatches工作表。删除单元格删除错误
https://bitbucket.org/openpyxl/openpyxl/issues/365/styling-merged-cells-isnt-working
"""
def merge_cells(self, range_string=None, start_row=None, start_column=None, end_row=None, end_column=None):
"""
在单元格范围中设置merge。Range是单元格范围(例如A1:E1)
这是monkeypatched删除单元格删除错误
"""
if not range_string and not all((start_row, start_column, end_row, end_column)):
msg = "You have to provide a value either for 'coordinate' or for\ 'start_row', 'start_column', 'end_row' *and* 'end_column'"
raise ValueError(msg)
elif not range_string:
range_string = '%s%s:%s%s' % (get_column_letter(start_column),
start_row,
get_column_letter(end_column),
end_row)
elif ":" not in range_string:
if COORD_RE.match(range_string):
return # 单个单元格,什么都不做
raise ValueError("Range must be a cell range (e.g. A1:E1)")
else:
range_string = range_string.replace('$', '')
if range_string not in self.merged_cells:
self.merged_cells.add(range_string)
#以下是由这个monkeypatch删除的:
# min_col, min_row, max_col, max_row = range_boundaries(range_string)
# rows = range(min_row, max_row+1)
# cols = range(min_col, max_col+1)
# cells = product(rows, cols)
# all but the top-left cell are removed
#for c in islice(cells, 1, None):
#if c in self._cells:
#del self._cells[c]
#使用monkey patch
worksheet.Worksheet.merge_cells = merge_cells
patch_worksheet()
在自己的程序中导入上面文件:
from fix_border import patch_worksheet
然后在load文件前加上patch_worksheet()
全部代码为(未验证):
ws = opx.load_workbook(filename1)
fix_border.patch_worksheet()
ws.save(filename2)
10、清除抓取的HTML特殊字符:
wz1 = re.sub('<.+?>', "", str) #去除str中的HTML标签
wz2 = wz1.replace('\\r', '\r').replace('\\n', '\n').replace('\\t', '\t').replace(r'\u3000', '').replace(r'\xa0', '').replace(' ', ' ').replace('“', '“').replace('”', '”').replace('[', '').replace(']', '').replace("'", '').replace('·', '·').replace('—', '—').replace('•', '•').replace('…', '…')
特殊符号
命名实体
十进制编码
特殊符号
命名实体
十进制编码
特殊符号
命名实体
十进制编码
Α
Α
Α
Β
Β
Β
Γ
Γ
Γ
Δ
Δ
Δ
Ε
Ε
Ε
Ζ
Ζ
Ζ
Η
Η
Η
Θ
Θ
Θ
Ι
Ι
Ι
Κ
Κ
Κ
Λ
Λ
Λ
Μ
Μ
Μ
Ν
Ν
Ν
Ξ
Ξ
Ξ
Ο
Ο
Ο
Π
Π
Π
Ρ
Ρ
Ρ
Σ
Σ
Σ
Τ
Τ
Τ
Υ
Υ
Υ
Φ
Φ
Φ
Χ
Χ
Χ
Ψ
Ψ
Ψ
Ω
Ω
Ω
α
α
α
β
β
β
γ
γ
γ
δ
δ
δ
ε
ε
ε
ζ
ζ
ζ
η
η
η
θ
θ
θ
ι
ι
ι
κ
κ
κ
λ
λ
λ
μ
μ
μ
ν
ν
ν
ξ
ξ
ξ
ο
ο
ο
π
π
π
ρ
ρ
ρ
ς
ς
ς
σ
σ
σ
τ
τ
τ
υ
υ
υ
φ
φ
φ
χ
χ
χ
ψ
ψ
ψ
ω
ω
ω
ϑ
ϑ
ϑ
ϒ
ϒ
ϒ
ϖ
ϖ
ϖ
•
•
•
…
…
…
′
′
′
″
″
″
‾
‾
‾
⁄
⁄
⁄
℘
℘
℘
ℑ
ℑ
ℑ
ℜ
ℜ
ℜ
™
™
™
ℵ
ℵ
ℵ
←
←
←
↑
↑
↑
→
→
→
↓
↓
↓
↔
↔
↔
↵
↵
↵
⇐
⇐
⇐
⇑
⇑
⇑
⇒
⇒
⇒
⇓
⇓
⇓
⇔
⇔
⇔
∀
∀
∀
∂
∂
∂
∃
∃
∃
∅
∅
∅
∇
∇
∇
∈
∈
∈
∉
∉
∉
∋
∋
∋
∏
∏
∏
∑
∑
−
−
−
−
∗
∗
∗
√
√
√
∝
∝
∝
∞
∞
∞
∠
∠
∠
∧
∧
⊥
∨
∨
⊦
∩
∩
∩
∪
∪
∪
∫
∫
∫
∴
∴
∴
∼
∼
∼
≅
≅
≅
≈
≈
≅
≠
≠
≠
≡
≡
≡
≤
≤
≤
≥
≥
≥
⊂
⊂
⊂
⊃
⊃
⊃
⊄
⊄
⊄
⊆
⊆
⊆
⊇
⊇
⊇
⊕
⊕
⊕
⊗
⊗
⊗
⊥
⊥
⊥
⋅
⋅
⋅
⌈
⌈
⌈
⌉
⌉
⌉
⌊
⌊
⌊
⌋
⌋
⌋
◊
◊
◊
♠
♠
♠
♣
♣
♣
♥
♥
♥
♦
♦
♦
¡
¡
¡
¢
¢
¢
£
£
£
¤
¤
¤
¥
¥
¥
¦
¦
¦
§
§
§
¨
¨
¨
©
©
©
ª
ª
ª
«
«
«
¬
¬
¬
®
®
®
¯
¯
¯
°
°
°
±
±
±
²
²
²
³
³
³
´
´
´
µ
µ
µ
"
"
"
<
<
<
>
>
>
'
'
11、报requests.exceptions.MissingSchema: Invalid URL ‘lianmeng.360.cn’: No schema supplied. Perhaps you meant http://lianmeng.360.cn? 错误
原因:无效URL,没有提供模式。
解决办法:在URL前加 http:// 即可解决,如 ‘http://’ + url。
手机扫一扫
移动阅读更方便
你可能感兴趣的文章