count = 0 #int
mile =1000.0 #python不区分单精度和双精度,float->双精度
name = "Mango" #字符串类型
n = n*10 # 等价于 n *=10
num++ #报错
++num #不报错,被当成了两个正号
#应该写成:
n += 1
python是一个动态类型语言, 即:一个变量在运行过程中,类型可以发生变化
a = 100
print(a) #100
a = 'Mango'
print(a) #Mango
Python没有int, float, 这样的关键字, 但是实际上数字的类型是区分 “int” “float” 这样的类型的. 使用内建函数 type 可以查看变量的类型.
a=1
print(type(a)) #
a = 1.0
print(type(a)) #
a = 1000 * 1000 * 1000 * 1000 * 1000 * 1000
print(a) #1000000000000000000
Python中还有一种 “复数” 类型. 和数学中的 “复数” 是相同的概念.
a = 10+5j #只能为j
print(a) #10+5j
Python中可以使用 单引号(‘), 双引号("), 三引号(’‘’/“”") 来表示字符串
a = 'he'
b = "hehe"
c = '''hehe'''
好处:不需要转义
例子:字符串如果包含了
"
这样的字符
a = 'My name is "Mango" '
print(a) #My name is "Mango"
a = "My name is 'Mango' "
print(a) #My name is 'Mango'
使用三引号
a = '''My 'name' is "Mango" '''
print(a) #My 'name' is "Mango"
例子:
a = 'My name is \\n "Mango" '
print(a) #My name is \n "Mango"
str = 'hehe'
#切片
print(str[0]) #h
print(str[-1]) #e
print(str[1:3]) #eh 左闭右开区间
print(str[:3]) #heh
print(str[1:]) #ehe
print(str[:]) #hehe
print(str[100]) #error 越界
切片:
省略左侧数字:从0开始(含0下标字符)
省略右侧数字:到-1结束(含-1下标字符)
两侧都省略:从头到尾
*
用于字符串重复 注意:只能*整数a = 'hehe'
b = "haha"
c = a+b #字符串拼接
print(c) #hehehaha
print(a*3) #hehehehehehe
print(a*3.0) #error 只能*整数
a = "hehe"
print(type(a[0])) #
a = "hehe"
print(len(a)) #4
不推荐写法1:
num = 100
a = 'num = %d' % num
print(a) #num = 100
a = 100
print("a = %d " %a) #a = 100
不太推荐
num = 100
a = 'num = {}'.format(num) #写法含义:把num的值替换到{}里面
print(a) #num = 100
推荐写法:python3.6以上才支持
加前缀f
num = 10
a = f'num = {num}' #直接把num替换进去
print(a) #num = 10
作为一个程序猿, 只要知道布尔值表示的是一个表达式的的 “真” 和 “假” 就行了
a = True
# a = true #error 首字母大写
print(a) #True
print(type(a)) #
a = True
b = False
c =0
print(a+c) #1
print(b+c) #0
print函数将结果输出到标准输出(显示器)上.
print打印完默认会换行
如果不想换行:多加一个参数
a = 'name'
print(a,end = ' ') #以空字符作为分割
input函数从标准输入中获取用户输入
name = input("请输入名字:") #可以附带输入提示
print(name)
#执行结果:
请输入名字:Mango
Mango
input返回的结果只是一个字符串. 如果需要获得一个数字, 需要使用eval函数把字符串转换成对应的指令
a = input()
# print(a +1) #error input返回的是字符串,不能把字符串和整数相加
print(eval(a) + 1)
Python中使用 # 作为单行注释. #后面的内容都是注释的内容
良好的注释, 也是一个优秀的程序猿必备的技能之一.
使用中文注释时, 要小心 直接使用可能会运行报错(Python3 目前已经没有这个问题了, Python2要注
意).
Python的源代码默认只支持ASCII, 所以如果要包含中文, 需要在代码文件最开头的地方注明
#coding: UTF-8 写在第一行
Python中支持 + - * / % 这样的操作符. 并且它们的行为都和C语言一样.
/ 是 “精确除法”
a = 1
b = 2
print(a/b) #0.5
// 是 “整除”. 会对结果进行取整
a = 1
b = 2
print(a//b) #0
** 表示乘方运算(记得Python的数据无上限) a**b <==> a的b次方
a = 100
b = 10
print(a**b) #100000000000000000000
Python也支持标准的比较运算符. > < >= <= == != 这些运算符的表达式的结果, 是一个布尔值
a = 2 < 4
print(type(a)) #
Python也支持逻辑运算符. and or not(相当于 与 或 非 ) 注意:符合短路原则
短路原则:
and:左边为False 就不看右边
or : 左边为True,就不看右边了
a = 2<4 and 2 == 4
print(a) #False
a = 2<4 or 2 == 4
print(a) #True
Python中, 3 < 4 < 5 等价于 3 < 4 and 4 < 5 这一点和其他大多数编程语言都不太一样.
运算符之间有高低优先级的区分. 应该合理使用括号来增加代码的可读性.
字符串和字符串之间也可以使用运算符进行操作,
print('hehe' + 'haha') #hehehaha
字符串之间可以使用 ==
!=
来判定字符串的内容是否相同
print('hehe' != 'haha') #True
print('hehe' == 'haha') #False
字符串之间也可以比较大小. 这个大小的结果取决于字符串的 “字典序”
C,C++,Java都是按字典序进行比较字符串
print('hehe' < 'haha') #False
print('mango' > 'Mango') #True
列表和元组类似于C语言中的数组.
使用 [] 来表示列表list
, 使用 () 来表示元组tuple
alist = [1,2,3,4] #列表
print(alist) #[1, 2, 3, 4]
print(len(alist)) #4
print(alist[1:-1]) #[2,3] 左闭右开
print(alist[1]) #2
print(alist[-1]) #4
atuple = (1,2,3,4) #元组
print(atuple) #(1, 2, 3, 4)
列表和元组能保存任意数量, 任意类型的Python对象
a = [1,'list']
print(a) #[1, 'list']
可以使用下标来访问里面的元素, 下标从0开始. 最后一个下标为-1
a = [1,'list']
print(a[0]) #1
print(a[1]) #list
print(a[1][2]) #s
可以使用[A:B]切片操作得到列表或元组的子集. 这个动作和字符串操作是一样的.注意:切片切出来的也是列表或元组
a = [1,'list']
print(a[:]) #[1, 'list']
print(a[0:1]) #[1]
列表和元组唯一的区别是, 列表中的元素可以修改, 但是元组中的元素不能修改.
a = [1,2,3,4]
a[0] = 100 #列表可变
a = (1,2,3,4)
a[0] = 100 #元组不可变 error
{}
表示字典.例子
键是怎么样,访问就怎么样.不同的键值对用逗号分割
键和值用:
分割 键要用''
括起来
a = {'ip':'127.0.0.1' , '1':'2'} #字典
print(a['ip']) #取字典中的元素 执行结果:127.0.0.1
a['port'] = 80 #插入新的键值对
print(a) #{'ip': '127.0.0.1', 'port': 80}
Python中可以用 id 这个内建函数, 查看变量的 “地址”
a = 100
print(id(a)) #140734889684720
a = 200 #给a重新赋值成200, 相当于新创建了一个200这样的对象, 然后将变量名a重新绑定到200这个对象上
print(id(a)) #140734889687920
b = a #将a赋值给b, 其实相当于又创建了一个变量名b, 并将b这个名字和200这个对象绑定到一起.
print(id(b)) #140734889687920
b = 300 #
print(id(b)) #2642453910960
像创建 a, b 这样的变量名, 其实只是一个对象的别名. 或者叫做变量的 “引用”,这个变量真正在内存开辟空间,但是a和b并不开辟空间,a和b相当于贴在这个变量身上的标签
党派1:
if (a > b)
{
do_something()
}
党派2
if (a > b){
do_something()
}
python:并不存在大括号. 因此也就不需要考虑大括号放在哪里了.
if a > b:
do_something()
如果表达式的值非0或者为布尔值True, 则执行 do_something, 否则执行下一跳语句.
注意:判断语句后面要加:
if expression:
do_something1
do_something2
next_something
Python也支持else语句
if expression:
do_something1
else:
do_something2
Python里还有神奇的的elif(意思是else-if)
if expression:
do_something1
elif expression2:
do_something2
else:
do_something3
Python并不支持switch/case这样的语句. 也没有必要支持. 实际上 switch/case 语法并不优雅.
while循环语句和if语句语法类似. 只要表达式的值非0或者为True, 就会循环执行do_something
注意:判断语句后面要加:
while expection:
do_something
例子:循环三次打印
count = 0
while count < 3:
print('loop %d' %count)
count+=1 #不可以用count++
#执行结果
loop 0
loop 1
loop 2
Python中的for循环和传统的for循环不太一样.
注意:判断语句后面要加:
#遍历打印字符串的每个字符
a = 'hehe'
for c in a:
print(c)
#执行结果
h
e
h
e
#遍历列表的每个元素
a =[1,2,3,4]
for item in a:
print(item)
#执行结果
1
2
3
4
#遍历字典中的所有key-value
a = {'ip':"198.168.1.1",'tel':'12345'}
for key in a:
print(a[key]) #打印键对应的值
print(key,a[key]) #打印键和值
#执行结果
198.168.1.1
ip 198.168.1.1
12345
tel 12345
内建函数range能够生成一个数字组成的列表, 方便进行for循环遍历.
for i in range(0,3):
print('loop %d' %i)
#执行结果
loop 0
loop 1
loop 2
range函数其实有三个参数.
如果只写一个参数:如 range(4) 相当于: range(0,4)
例子:遍历[0,10)区间的偶数
for i in range(0,100,2):
print(i)
#执行结果:
0
2
4
6
8
使用break语句跳出当前循环
例子
#查找[0,100)第一个3的倍数
for i in range(0,100):
if i %3 ==0:
break
使用continue语句, 回到循环顶端, 判定循环条件,循环条件满足, 则执行下一次循环
#打印[0,10)所有3的倍数
for i in range(0,10):
if i %3 != 0:
continue
print(i)
#执行结果
0
3
6
9
有时候需要用到 空语句 这样的概念, 什么都不做. 由于没有 {} , 需要有一个专门的语句来占位, 要不缩进就混乱了
if x%2 ==0:
pass
else:
do_something
用一个表达式构造列表
使用for循环将生成的值放在一个列表中
例子1:
#生成[0,4)的数字的平方序列
s = [x**2 for x in range(4)]
print(s) #[0, 1, 4, 9]
例子2:
#获取[0,8)区间中所有的奇数
evens = [x for x in range(8) if x%2 ==1]
print(evens) #[1, 3, 5, 7]
注意:最后面的:
一些可以被重复使用的代码, 可以提取出来放到函数中.
Python使用def来定义一个函数. 使用return来返回结果
def Add(x,y):
return x+y
Python使用()来调用函数
def func():
print("a")
def func():
print("b")
func() #打印b
Python支持默认参数. 函数的参数可以具备默认值,即:调用时没有传参或者少传参,默认为某个数(缺省值)
def Add(x = 0,y = 1):
return x+y
print(Add(10)) #10+1=11
print(Add()) #0+1=1
Python解包(unpack)语法, 函数返回多个值
def GetPoint():
return 100,200
x,y = GetPoint()
print(x,y)#100 200
def GetPoint():
return 100,200
_,y = GetPoint() #_是占位符
print(y)#200
def Func():
print("aaa")
print(type(Func)) #直接取函数名打印类型,不需要调用
func = Func #func就是函数Func的别名
func();#调用func函数 aaa
print(type(func)) #
例如:
str = "Mango"
print(len(str))#len函数的返回值作为print函数的参数
handle = open(file_name,access_mode = 'r')
file_name是文件的名字. 可以是一个绝对路径, 也可以是相对路径.
handle = open('test.txt',access_mode = 'r') #相对路径
handle = open('Z:\test.txt',access_mode = 'r') #绝对路径
access_mode是文件的打开方式. 选项有以下几种
例如:写文件
f = open("...","W")
f.write('写入的内容')
handle是一个文件句柄, 是一个可迭代的对象. 可以直接使用for循环按行读取文件内容.
for line in handle:
print(line)
handle.close()
一个文本文件中, 每一行是一个单词. 可能有重复. 统计每个单词出现的次数.
in 和 not in 是关键字查找
Bug代码1:
handle = open('test.txt',mode = 'r') #以只读方式,打开Z盘下的test.txt文件
words = {} #创建空字典
#读取
for word in handle:
word = word[:-1] #切片,去掉最后的换行符\n
#如果当前行的单词不在字典中,就插入新键值对 否则次数+1
if word not in words:
words[word] = 1
else:
words[word] +=1
handle.close()
print(words)
切片的时候出了问题,所以我们换一种方式: 使用字符串的
strip
函数 :去掉字符串两侧的空白字符
handle = open('test.txt',mode = 'r') #以只读方式,打开Z盘下的test.txt文件
words = {} #创建空字典
#读取
for word in handle:
word =word.strip()#去掉字符串两侧的空白字符
#如果当前行的单词不在字典中,就插入新键值对 否则次数+1
if word not in words:
words[word] = 1
else:
words[word] +=1
handle.close()
print(words)
当我们一个项目的代码量较大的时候, 需要把代码放到多个不同的.py文件中. 起到了命名空间的效果
例子:
add.py的内容:
def Add(x,y):
return x+y
test.py的内容,直接import模块名 不需要加后缀.py
#方式1:导入模块
import add #导入add文件
print(add.Add(1,2)); #打印3 要利用模块进行调用里面的函数
#方式2:导入模块中的函数,直接调用
from add import Add #导入add模块中的Add函数
print(Add(1,2))#打印3 直接调用Add函数
#还可以import 模块名 然后给模块名取别名
import add
a = add
print(a.Add(1,2))#打印3
运用模块,在不同文件命名一样名字的函数,就不会导致覆盖
一个模块想要被正确导入,必须放到合适的目录下
模块查找的顺序, 先是查找当前目录, 然后查找Python的安装目录.