编码格式
Posted 星空的衣角
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了编码格式相关的知识,希望对你有一定的参考价值。
一、Python的编码格式
支持中文的编码有:utf-8、gbk、gb2312,在其他应用中很多默认是用utf-8的格式,而在Windows的cmd中输出中文需要使用gbk格式
Python2.X中默认的编码格式是 ASCII 格式,在没修改编码格式时无法正确打印汉字,所以在读取中文时会报错,解决方法只要在文件开头加入 # -*- coding: UTF-8 -*- 或者 #coding=utf-8 就行了
#!/usr/bin/python
# -*- coding: UTF-8 -*-
print "你好,世界";
Python2.X中如果要想让Windows下cmd显示中文,需要将编码格式改为gbk,或者在代码中加入如下:
import sys
reload(sys)
print(sys.getdefaultencoding())
sys.setdefaultencoding("utf -8")
print(sys.getdefaultencoding())
注意:Python3.X 源码文件默认使用utf-8编码,所以可以正常解析中文,无需指定 UTF-8 编码。
还有一种格式是可以用转换来完成的:原有编码 --> unicode编码 --> 目的编码,指的是在字符串前面加上u,表示是以Unicode编码格式存储,当打印的时候它会根据客户端需要的编码格式自动转换为所需的编码,如下:
m = u"哈哈哈"
print(m)
或者可以在打印输出的时候做解码和编码操作,指的是先用decode转换成Unicode格式,再用encode转换成所需的编码格式,如下:
n = "你好"
print(n.decode("utf-8").encode("gbk"))
decode("utf-8")解码 -> unicode -> encode("gbk")
二、练习题
1)、判断一个字符串数字有多少个,字符有多少个,空格有多少个,其他字符有多少个
while 1:
strings = input("Please input a string(input quit is exit): ")
dig, alpha, space, other = 0, 0, 0, 0
if strings.strip() == "quit":
exit()
else:
for i in strings:
if i.isdigit():
dig += 1
elif i.isalpha():
alpha += 1
elif i.isspace():
space += 1
else:
other += 1
print("dig = {0},alpha = {1},space = {2},other = {3}".format(dig, alpha, space, other))
2)、ABCD乘以9=DCBA,求ABCD各为多少
for a in [1]:
for b in range(0, 10):
for c in range(0, 10):
for d in [9]:
if (a*1000+b*100+c*10+d)*9 == d*1000+c*100+b*10+a:
print("a={0},b={1},c={2},d={3}".format(a, b, c, d))
3)、九宫格
-------------
| A | B | C |
| D | E | F |
| G | H | I |
-------------
所有横竖斜线加起来都等于15
number = list()
for i in range(1, 10):
number.append(i)
for A in number:
a = number.copy()
a.remove(A)
for B in a:
b = a.copy()
b.remove(B)
for C in b:
c = b.copy()
c.remove(C)
for D in c:
d = c.copy()
d.remove(D)
for E in d:
e = d.copy()
e.remove(E)
for F in e:
f = e.copy()
f.remove(F)
for G in f:
g = f.copy()
g.remove(G)
for H in g:
h = g.copy()
h.remove(H)
for I in h:
if (A + B + C == D + E + F == G + H + I == A + D + G == B + E + H == C + F + I == A + E+ I == C + E + G== 15):
print("""
-------------
| {0} | {1} | {2} |
| {3} | {4} | {5} |
| {6} | {7} | {8} |
-------------""".format(A, B, C, D, E, F, G, H, I))
4)、阶乘
0!+ 1!+ 2!+ 3!+...+ n!
def jc(n):
result = 1
if n == 0:
return result
else:
for i in range(1, n + 1):
result *= i
return result
n = input("Pls input num: ")
count = 0
for i in range(0, int(n) + 1):
count += jc(i)
print("count={0}".format(count))
以上是关于编码格式的主要内容,如果未能解决你的问题,请参考以下文章
从 XML 声明片段获取 XML 编码:部分内容解析不支持 XmlDeclaration
如何在 Javadoc 中使用 @ 和 符号格式化代码片段?
《安富莱嵌入式周报》第279期:强劲的代码片段搜索工具,卡内基梅隆大学安全可靠C编码标准,Nordic发布双频WiFi6 nRF7002芯片