Hello, World!
首先肯定是最经典的Hello, World!
#!/usr/bin/env python3
print("Hello, World!")
第一行被注释掉的其实是想要指出代码使用什么可执行程序去解释,这里不使用#!/usr/bin/python3其实是因为很有可能没有把python3装在该路径下,因此我们去调用env里去查找安装路径,再去调用对应路径下的解释器程序完成操作。
变量
pyhon3中现在可以用中文作为变量名,非ASCⅡ标识符也是允许的,习惯与C类似。
保留字:
>>> import keyword
>>> keyword.kwlist
['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class', 'continue', 'def',
'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in',
'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while',
'with', 'yield']
代码注释使用#,' ' ',""":
#!/usr/bin/python3
# 第一个注释
# 第二个注释
'''
第三注释
第四注释
'''
"""
第五注释
第六注释
"""
print ("Hello, Python!")
行与缩进
python不像C语言一样使用{}而是使用缩进表示代码块,因此同一个代码块的语句必须包含相同的缩进空格数,若缩进不一致就会运行错误。
我们通常的习惯是一行写完一条语句,但是在python中,如果语句很长,我们就可以使用反斜杠\来实现多条语句,但是在[]、{}、()中的多行语句就无需使用反斜杠\。
数据类型
int型,整数,在python中只有一种整数类型int表示长整型。
bool,与C语言类似True、False。
float,浮点数。
complex,复数,1+j。
String,字符串。python中使用单引号'和双引号"完全相同,使用三引号' ' '或"""可以指定一个多行字符串,与C语言一样使用转义符号\,如果不想转义则使用r让反斜杠不发生转义, 如 r"this is a line with \n" 则 \n 会显示,并不是换行。使用+可以将字符转连接在一起,使用*运算符重复字符串。python中的字符串有两种索引方式,从左往右以0开始,从右往左以-1开始。截取语法格式:变量[头下标:尾下标:步长]。
str='123456789'
print(str) # 输出字符串
print(str[0:-1]) # 输出第一个到倒数第二个的所有字符
print(str[0]) # 输出字符串第一个字符
print(str[2:5]) # 输出从第三个开始到第五个的字符
print(str[2:]) # 输出从第三个开始后的所有字符
print(str[1:5:2]) # 输出从第二个开始到第五个且每隔一个的字符(步长为2)
print(str * 2) # 输出字符串两次
print(str + '你好') # 连接字符串
print('------------------------------')
print('hello\nrunoob') # 使用反斜杠(\)+n转义特殊字符
print(r'hello\nrunoob') # 在字符串前面添加一个 r,表示原始字符串,不会发生转义
代码格式
函数之间或类的方法之间用空行分隔,虽说空行与否不会对代码运行产生影响,但是能够分割两段不同含义的代码,便于日后代码的维护或重构,同一行写多条语句需使用;隔开。
缩进相同的一组一句构成一个代码块,像if、while、def和class这样的复合语句,首行以关键字开始,以冒号(:)结束,该行之后的一行或多行代码构成代码组。
print输出
print 默认输出是换行的,如果要实现不换行需要在变量末尾加上 end="":
x="a"
y="b"
# 换行输出
print( x )
print( y )
print('---------')
# 不换行输出
print( x, end=" " )
print( y, end=" " )
print()
转换类型
a='2.1'
print(int(float(a)))
导入模块
在 python 用 import 或者 from...import 来导入相应的模块。
导入sys模块
import sys
print('================Python import mode==========================')
print ('命令行参数为:')
for i in sys.argv:
print (i)
print ('\n python 路径为',sys.path)
导入sys模块的成员
from sys import argv,path # 导入特定的成员
print('================python from import===================================')
print('path:',path) # 因为已经导入path成员,所以此处引用时不需要加sys.path
基本数据类型
python中变量无需声明,但使用前必须赋值,变量赋值之后才会被创建。而且在python中变量没有类型这个概念,我们所说的类型是变量所指的内存中对象的类型。
counter = 100 # 整型变量
miles = 1000.0 # 浮点型变量
name = "runoob" # 字符串
print (counter)
print (miles)
print (name)
python中也允许同时为多个变量赋值。
a = b = c = 1
a, b, c = 1, 2, "runoob"
python3中有六个标准的数据类型:number、string、list、tuple、set、dictionary。其中数字、字符串和元组不可变,而列表、字典和集合可变。
Number
python3中支持int、float、bool、complex,内置的type()函数可以查询变量所指的函数类型。此外还可以用isinstance()来判断,type函数不会认为子类是一种父类类型,isinstance会认为子类是一种父类类型。
a, b, c, d = 20, 5.5, True, 4+3j
print(type(a), type(b), type(c), type(d))
a = 111
isinstance(a, int)
也可以使用del语句删除一些对象引用
del var1[,var2[,var3[....,varN]]]
del var
del var_a, var_b
运算:
>>> 5 + 4 # 加法
9
>>> 4.3 - 2 # 减法
2.3
>>> 3 * 7 # 乘法
21
>>> 2 / 4 # 除法,得到一个浮点数
0.5
>>> 2 // 4 # 除法,得到一个整数
0
>>> 17 % 3 # 取余
2
>>> 2 ** 5 # 乘方
32
TIPS:
- 数值运算除法,单斜杠返回浮点数双斜杠返回整数。
- 在混合运算时,python会把整型转换成浮点数。
- python中的复数,a+bj其中的a,b都是浮点型。
String
python中字符串用'或"括起来,同时使用反斜杠转义特殊字符,对于一个字符串以0为起始值,-1为末尾最开始的位置。
TIPS:
- 反斜杠可以用来转义,使用r可以让反斜杠不发生转义。
- 字符串连接使用+重复使用*。
- python中的字符串不能改变。
List
列表可以完成大多数几何类的数据结构实现。列表中的元素类型可以不相同,它支持数字,字符串甚至可以包含列表(也就是嵌套)。列表时写在[]之间、使用,分隔的元素列表。和字符串一样,列表同样可以被索引和截取,列表被截取后返回一个包含所需元素的新列表。
list = [ 'abcd', 786 , 2.23, 'runoob', 70.2 ]
tinylist = [123, 'runoob']
print (list) # 输出完整列表
print (list[0]) # 输出列表第一个元素
print (list[1:3]) # 从第二个开始输出到第三个元素
print (list[2:]) # 输出从第三个元素开始的所有元素
print (tinylist * 2) # 输出两次列表
print (list + tinylist) # 连接列表
与字符串不同,List中的元素可以改变,且内置了很多方法如append()、pop()等等。
翻转字符串:
def reverseWords(input):
# 通过空格将字符串分隔符,把各个单词分隔为列表
inputWords = input.split(" ")
# 翻转字符串
# 假设列表 list = [1,2,3,4],
# list[0]=1, list[1]=2 ,而 -1 表示最后一个元素 list[-1]=4 ( 与 list[3]=4 一样)
# inputWords[-1::-1] 有三个参数
# 第一个参数 -1 表示最后一个元素
# 第二个参数为空,表示移动到列表末尾
# 第三个参数为步长,-1 表示逆向
inputWords=inputWords[-1::-1]
# 重新组合字符串
output = ' '.join(inputWords)
return output
if __name__ == "__main__":
input = 'I like runoob'
rw = reverseWords(input)
print(rw)
Tuple
元组与列表类似,不同之处在于元组的元素不能修改。元组写在小括号()里,元素之间用逗号隔开,元组中的元素类型也可以不相同。
tuple = ( 'abcd', 786 , 2.23, 'runoob', 70.2 )
tinytuple = (123, 'runoob')
print (tuple) # 输出完整元组
print (tuple[0]) # 输出元组的第一个元素
print (tuple[1:3]) # 输出从第二个元素开始到第三个元素
print (tuple[2:]) # 输出从第三个元素开始的所有元素
print (tinytuple * 2) # 输出两次元组
print (tuple + tinytuple) # 连接元组
元组与字符串类似,可以被索引且下标索引从0开始,-1 为从末尾开始的位置。也可以进行截取,可以把字符串看作一种特殊的元组。
Set
集合是由一个或数个形态各异的大小整体组成的,构成集合的事物或对象称作元素或是成员。基本功能是进行成员关系测试和删除重复元素。可以使用大括号 { } 或者 set() 函数创建集合,创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
sites = {'Google', 'Taobao', 'Runoob', 'Facebook', 'Zhihu', 'Baidu'}
print(sites) # 输出集合,重复的元素被自动去掉
# 成员测试
if 'Runoob' in sites :
print('Runoob 在集合中')
else :
print('Runoob 不在集合中')
# set可以进行集合运算
a = set('abracadabra')
b = set('alacazam')
print(a)
print(a - b) # a 和 b 的差集
print(a | b) # a 和 b 的并集
print(a & b) # a 和 b 的交集
print(a ^ b) # a 和 b 中不同时存在的元素
Dictionary
字典(dictionary)是Python中另一个非常有用的内置数据类型。列表是有序的对象集合,字典是无序的对象集合。两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。字典是一种映射类型,字典用 { } 标识,它是一个无序的 键(key) : 值(value) 的集合。键(key)必须使用不可变类型。在同一个字典中,键(key)必须是唯一的。
dict = {}
dict['one'] = "1 - 菜鸟教程"
dict[2] = "2 - 菜鸟工具"
tinydict = {'name': 'runoob','code':1, 'site': 'www.runoob.com'}
print (dict['one']) # 输出键为 'one' 的值
print (dict[2]) # 输出键为 2 的值
print (tinydict) # 输出完整的字典
print (tinydict.keys()) # 输出所有键
print (tinydict.values()) # 输出所有值
数据类型转换
python可以自动将一种数据类型转换成另一种数据类型,无需干预,比如两种不同数据类型进行计算时,较低数据类型会转换为较高数据类型以避免数据丢失。
但是无法进行直接运算的类型就不能隐式转换,需要使用函数进行类型转换。