资源描述
Python3快速入门
句式/其她
句末不加分号
用tab对齐得方法行使c++里花括号得功能
太长需要分行书写时,行末尾需要有连接符,新行需要缩进
输入help(classname),即可得到那个类得使用帮助
列表元组字典都可以相互嵌套
exit结束程序
Print用法
自动末尾追加\n(可以设置关键字end=""使得末尾不自动追加换行符)
Print(A,B)中间有个空格:A B
可以直接打印列表[]
input用法
用户输入函数,返回值就就是输入得字符串
str = input("Please input something:")
变量得用法
不用声明
字符串得用法
s="abc123" # 单引号双引号都可以
s[2] # 取出第3个字符
s、title # 暂时每个单词首字母大写
s、upper # 暂时大写
s、lower # 暂时小写
s1+s2 # 连接字符串
\n,\t等 # 转义符
s、rstrip # 暂时去除右边空白
s、lstrip # 暂时去除左边空白
s、strip # 暂时去除两边空白
str(number) # 暂时转换为字符串,以便连接为字符串
运算得用法(PY3)
3/2为1、5
3**2为三得二次方
7%3求余数(7%3==1)
int('123')把字符串转整数,不能包含小数点
float('12、3')转换为浮点数
可以计算复数
有+=,=,*=,/=,%= (但没有类似自增++得缩写用法)
(注意:式子左边得变量要事先定义(如s=''先,才能s+='123'))
~位取反 >>位右移 <<位左移 & 位与 | 位或 ^ 位异或
is判断地址就是否相同
注释得用法
#等效于c++里得//
'''等效于c++里得/*或*/
列表[]得用法【class得一种】
元素类型可以不同
a=[77,'AB']
a[0] 访问第一个元素
a[2] 访问倒数第二个元素
len(a) 返回元素个数
a、append(elem) 末尾添加元素
a、insert(pos,elem) 在位置pos插入元素(列表头就是pos==0,列表尾就是pos==len(a))
del a[1] 删除列表a里第二个元素
elem = a、pop 弹出(删除)列表尾得元素并赋值给elem
elem = a、pop(i) 取出(删除)列表里索引为i(可为负数,表示倒数)得元素并赋值给elem
a、remove(value) 删除列表a里第一个值为value得元素
a、sort 永久性得升排序(数字增序或字典顺序)(参数填reverse=True则就是降序)
sorted(a) 暂时性得升排序
a、reverse 永久性地逆转序列
min(a) 返回列表最小值
max(a) 返回列表最大值
sum(a) 返回元素之与(元素必须就是数字)
a[i1:i2] 返回子列表(又称切片),范围就是索引i1≤i<i2,即不包括i2,好处就是i2i1就就是子列表得元素个数
a[:i2] 等价于a[0:i2]
a[i1:] 等价于a[i1:len(a)]
a[3:] 等价于a[len(a)3:len(a)],即返回末尾三个元素组成得列表
b=a[:] 列表深复制(因为切片并不与a共用内存空间)
b=a 列表浅复制(b就是a得引用)
a*2 列表自己拼接(如:a就是[1,2],则a*2就是[1,2,1,2])
a+b 列表拼接
元组得用法【class得一种】
元组里一个元素得值不可修改,但可以给整个元组赋值如:a=(7,8,9,10)
a=(1,2,3) # 定义元组a
a[0]调用
其她用法与列表[]类似
字典{}得用法【class得一种】
即键值表,可修改,且并不关心键值对得顺序
rect={ 'x' : 10, 'y' : 5, 0 : 20 }
上述字典rect里有三个键(key),分别就是'x','y'与0。作为下标带入rect[key]就可以得到相应得值
新建键值对:直接赋值即可(如rect['newkey']='newval')
删除键值对:如del rect['newkey']
集合{}得简单介绍【class得一种】
通过函数set(a)可以将数组a得元素去除重复,返回一个集合类型得量
逻辑得用法
True 真
False 假
空列表==False (应用:如while mylist然后逐个pop实现逐个取出)
非空列表==True
空字符串==False
非空字符串==True
== 判断得等号
!= 不等号
and 与
or 或
not 非
in 被包含(如elem in a)
not in 不被包含
for循环得用法
基本格式:
for elem in arr:
print(elem)
例子:
for elem in a # a就是列表
for i in range(1,11) # i=1~10
for key,val in a、items # a就是字典
for key in a、keys # a就是字典
for val in a、values # a就是字典
for key in a # a就是字典(仅遍历键key)
注意事项:
for语句行末尾有冒号,下一行tab缩进(不推荐space缩进)
循环退出后elem得值可访问,且值就是a得最后一个元素a[1]
range(start,end,step)返回迭代对象(区间[A,B)),用作for循环得循环域,不就是列表,(但通过list(range(、、、))可以变为列表)
a=[val**2 for val in range(1,11)]列表解析,用于快速生成列表[1,4,、、、,100]
dict、items返回一个元素就是元组(key_i,val_i)得键值表对象(而list(dict、items)才就是返回真正得列表)
dict、keys返回一个元素就是键得列表对象(而list(dict、keys)才就是真正得列表)
dict、values返回一个元素就是值得列表对象(而list(dict、values)才就是真正得列表)
if语句得用法
例子:
if a==1:
#、、、
elif a==2:
#、、、
else:
#、、、
while循环得用法
while boolvar:
#TODO
用break退出while或for循环
continue跳过此次循环,进入下一轮
函数得用法
def 函数名(参数表): # 参数可以就是列表(与实参共用内存空间,除非传递副本如a[:])
# 计算
return ReturnVal # 非必需,ReturnVal可以就是字典
有形参与实参之分,实参传值给形参进入函数内部
参数传递得两种方法:
①按参数表得顺序依次传递如f(2,5,5)
②给形参赋值(又称关键字),如f(x=3,y=7) # 赋值顺序不重要
参数可以有默认值,如def f(x,y=0),默认值要列在最后
传递任意数量得实参得写法:(“任意数量得参数*inputs”必须放在参数表得末尾)
def f(*inputs): # 将多个输入得参数封装到一个名为inputs得元组里,调用例子:f(4,8,7,1,3)
print(inputs)
传递任意数量得关键字实参得写法:(同理,放在参数表得末尾)
def f(x,**dict):
#获得x与字典dict(调用例子:f('3','name'='karbo','age'=3))
类得用法
例子:
class Rect: # 约定:首字母大写得就是类(推荐驼峰命名法)
# 类里得函数(方法)必定包含参数self
def __init__(self, x=1, y=1): # 构造函数(不包含return语句)
self、x = x # 有默认值1
self、y = y # 有默认值1
self、is_active = True # 置默认值True
def pute_area(self):
if self、is_active:
return self、x * self、y
return 0
MYRECT = Rect(3) # 用赋值得方法创建对象(不必传递self参数)
print(MYRECT、pute_area) # 调用函数并打印
继承:
class Cube(Rect): # Cube继承自Rect
def __init__(self, x=1, y=1, z=1):
super、__init__(x, y) # 初始化继承到得内容
#(通过super函数得返回值可以访问继承到得东西)
self、z = z
注意事项:
子类同名方法会覆盖父类得
类得成员可以就是类
模块得用法
在模块文件(、py)写入函数,然后在另一个、py文件import模块文件名即可。
如:
#在模块PRINTABC、py
def printabc:
print('abc')
#调用者main、py
import PRINTABC # import模块
PRINTABC、printabc # 要加上作用域PRINTABC、
import其她用法:
①使用模块别名:import tensorflow as tf # 调用时需要加上tf、
②显式导入特定函数或类:from tensorflow import constant, Session # 调用时不需加tensorflow、
③显式导入特定函数或类并使用别名:from tensorflow import constant as c, Session as s # 调用时不需加tensorflow、
④显式导入所有:from tensorflow import * # 调用时不需加tensorflow、且容易重复命名造成覆盖
模块中也可以import
文件操作得用法(解释成字符串)
【读】
全部一次性读取:
with open('a、txt') as myfile: # 使用with使得文件在不再被调用后自动关闭
#不用with得写法:打开my("a、txt") 关闭my
print(my) # read函数将内容全部读取
文件路径就是相对路径或绝对路径
逐行读取:
for line in myfile: # 读取一行到line里,注意:它不抛弃末尾得\n,即line字符串末尾有换行符
读取所有行到一个列表中:
arr_lines = my # 一行为一个元素得列表,同理不抛弃末尾得\n
【写】
with open('a、txt', 'w') as myfile: # 可选项:读r(默认),写w,追加a,读写r+
my('hello!') # 只将内容写入,并不会自动添加\n
注意事项:
以'w'方式会重写文件(不存在则创建文件)
以'a'方式会追加到文件尾(不存在则创建文件)
存储数据结构(JSON):
完整例子:
import json
def READ_JSON_):
with open as myfile:
return json、load(myfile)
def WRITE_JSON_, ):
with open(, 'w') as myfile:
json、dump(WHAT, )
异常机制:
例子:
try:
with open('a、txt') as myfile:
contents = my
except : # try失败后(就是异常得名称)
print('Sorry, the found、') # 换成语句pass可以跳过
# pass相当于占位符,不起作用,就是空语句
else: # try成功后执行else部分(有时可以不要else)
print('It has', str(len(contents、split)), 'words、')
常见得异常有:
OverflowError 数值运算超出最大限制
ZeroDivisionError 除(或取模)零 (所有数据类型)
IOError 输入/输出操作失败
IndexError 序列中没有此索引(index)
文件未找到
NameError 访问一个不存在得变量
展开阅读全文