Java程序员学习python需要注意的地方(不间断更新)

版权声明:@CopyRight转载请注明出处 https://blog.csdn.net/LI_AINY/article/details/86506368

Java程序员学习python需要注意的地方

参考地址廖雪峰的官方网站

  1. /除法计算结果是浮点数,即使是两个整数恰好整除,结果也是浮点数:
>>> 10 / 3
3.3333333333333335
  1. 还有一种除法是//,称为地板除,就是平常所说的四舍五入,两个整数的除法仍然是整数:
>>> 10 // 3
3
  1. 如果字符串内部有很多换行,用\n写在一行里不好阅读,为了简化,Python允许用’’’…’’'的格式表示多行内容
print('''line1
line2
line3''')
  1. 以Unicode表示的str通过encode()方法可以编码为指定的bytes
>>> 'ABC'.encode('ascii')
b'ABC'
>>> '中文'.encode('utf-8')
b'\xe4\xb8\xad\xe6\x96\x87'
>>> '中文'.encode('ascii')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)

纯英文的str可以用ASCII编码为bytes,内容是一样的,含有中文的str可以用UTF-8编码为bytes。含有中文的str无法用ASCII编码,因为中文编码的范围超过了ASCII编码的范围,Python会报错。

  1. 如果我们从网络或磁盘上读取了字节流,那么读到的数据就是bytes。要把bytes变为str,就需要用decode()方法
>>> b'ABC'.decode('ascii')
'ABC'
>>> b'\xe4\xb8\xad\xe6\x96\x87'.decode('utf-8')
'中文'
>>> b'\xe4\xb8\xad\xff'.decode('utf-8')
Traceback (most recent call last):
  ...
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 3: invalid start byte

如果bytes中包含无法解码的字节,decode()方法会报错

  1. 计算str包含多少个字符户或字节,可以用len()函数
>>> len('ABC')
3
>>> len('中文')
2
  1. 在Python中,采用的格式化方式和C语言是一致,用%实现。%运算符就是用来格式化字符串的。在字符串内部,%s表示用字符串替换,%d表示用整数替换,有几个%?占位符,后面就跟几个变量或者值,顺序要对应好。如果只有一个%?,括号可以省略。
>>> 'Hello, %s' % 'world'
'Hello, world'
>>> 'Hi, %s, you have $%d.' % ('Michael', 1000000)
'Hi, Michael, you have $1000000.'
  1. list里面的元素的数据类型也可以不同,变量不需要定义类型,是动态的,java是静态的,需要定义具体类型
>>> L = ['Apple', 123, True]

猜你喜欢

转载自blog.csdn.net/LI_AINY/article/details/86506368