Xu An 2018-3-7
1、Python print
#在Python3.X中使用print()进行输出,而2.x中使用()会报错 print("hello world") print('I\'m apple') #如果全部使用单引号,则需要在前面加上转义字符\+引号 print('apple'+'pear') print('apple'+str(4)) #将数字转换为字符串并打印 print(int("1")+2)#将字符串转换为整数类型
2、pyhton数值运算
print(2**2) #幂运算为** print(10%3) #取余数为% print(9//4) #取整数为//
3、自变量定义
a,b,c=1,2,3 #一次定义多个变量 print(a,b,c)
4、while循环
condition=1 while condition<10: print(condition) condition+=1
5、for循环(相当于迭代器)
x=1 y=2 z=3 if x<y<z: print("x is less than y")
6、if-else语句
if x<y: print("x<y") else: print("x>y")
7、if-elif-else
if x<y: print("x<y") elif x==y: print("") else: print("x>y")
8、函数定义
def add(a,b): #在python中定义函数需要使用def() c=a+b print("This is the result of the addtion:",c) add(1,3)
9、默认函数参数
def car(price,color='red',second_hand=True): #在函数参数后面加=“默认值”可以完成默认值的赋值 #bool类型中的参数需要大写True、Flase #需要把默认参数放到变量的后面 print('price',price, 'color',color, 'second_hand',second_hand, ) car(1000)
10、变量类型
'''
(1)全局变量
在模块内、所有函数外、class外的变量,可以被全局共享,也可以被外部文件共享
全局变量使用时,需要使用global显式声明
如果不将全局变量更新,一般不需要加global声明
如果有重新赋值,又没有在函数内部使用global声明时,相当于在内部创建了一个同名的局部变量
同名局部变量优先级高于未显式声明的全局变量
'''
APPLE=10 #全局变量需要在函数外部定义 def test10_01(): global APPLE #在函数内部定义全局变量 APPLE=20 #在函数内声明的局部变量的优先级高于全局变量 print(APPLE) test10_01()
'''
(2)局部变量
在函数内、class方法内(未加self修饰)
生命周期在函数执行时,当函数执行完毕后局部变量消亡
'''
def test10_02(): city='shijiazhuang' print(city)
'''
(3)静态变量(类变量)
通过类名直接访问,也可以通过实例名直接访问,变量在类中、实例间全局共享
'''
# class foo: # all=0 # def add(self): # foo.q+=1 # ins_1=foo() #实例化对象1 # ins_2=foo() #实例化对象2 # print(ins_1.all) #0 # print(ins_2.all) #0 # print(foo.all) #0 # ins_1.add() #静态全局变量加1
'''
(4)实例变量
对于模块来说,拥有自己的全局变量,可以供自己内部的类,函数使用
对于类或者方法来说,有自己的局部变量,供自己内部使用
对于类,有了静态变量,可以供内部和有继承关系的父子使用
实例间各自的局部变量需要靠动态绑定多态实现
'''
class foo_1: all=0 def __init__(self,name): self.name=name def add(self): foo.q+=1
'''
(5)总结
私有变量:自己独享的变量,如函数和方法的局部变量,实例变量
公有变量:需要在一定范围内共享,达到同步的目的,如模块内的代码共享的全局变量,类与子类之间共享的静态变量
'''
11、文件写入
text="This is my first text.\nThis is next line\n" #使用\n表示换行,主要换行指令与C++一致 print(text) my_file=open('1.txt','w') #open可以打开一个文件,open(‘文件路径’,‘形式’),形式w为可写形式,r为只读形式 my_file.write(text) #在文件中写入相应的语句 my_file.close() #切记在文件写入后要使用close方法关闭文件 print('Flie writing completed.')
12、文字内容追加
my_file=open('1.txt','a') #方式a是append的缩写,表示文件的追加模式 append_text="this is appened text" my_file.write(append_text) my_file.close()
# 13、读文件
my_file=open('1.txt','r') #r为读模式 content=my_file.read() #读取文件内容需要使用read()方法 second_read=my_file.readline() third_read=my_file.readline() #readline为逐行输出文字 all_read=my_file.readlines() #逐行读取后会将读取的元素按行放置在一个列表中 print(content,'second_read',second_read,'third_read',third_read,'all_read',all_read)
14、类(class)
class Calculator: #类一般为大写 def __init__(self,name,price): #构造函数,在进行对象实例化时必须赋值,前面需要加上self self.name=name self.price=price name="Calculator" price=10 def add(self,x,y): print(self.name) #如果要在类内调用本身的方法,需要加上self.属性名或self.方法名 result=x+y print(result) def minus(self,x,y): result=x-y print(result) def times(self,x,y): result=x*y print(result) def devide(self,x,y): result=x/y print(result) newcalulator=Calculator('name',10) print(newcalulator.name)
15、input
a_input=input('Please give me a number:') #input的功能为输入,其后面的括号为提示信息,input的返回值为输入的内容(是str类型),并赋值给对应的参数 int_input=int(a_input) #对字符串需要转换为int类型后进行判断 if int_input==1: print('your input is 1') elif int_input==2: print('your input is 2') else: print('your input number is other')
16、元组 使用小括号或者不使用括号
a_tuple=(1,2,3,43) #元组可以用小括号的形式,也可以不加小括号 another_tuple=1,12,43,23 for x in a_tuple: print(x)
17、列表 使用中括号
a_list=[12,34,23,43] for x in a_list: #将list的值使用for循环放到x中,之后打印出来 print(x) for index in range(len(a_list)): #range()会生成一个迭代器,index为索引 print("index=",index,'number in list=',a_list[index]) a=[1,2,3,4,5] a.append(0) #在列表后面追加一个元素 print(a) a.insert(1,0) #insert(添加位置,数值) a.remove(2) #remove(第一次出现的数值) print(a[3:5]) a.index(1)#列表中第一次出现该数值的索引 a.sort(reverse=True) #默认为从小到大进行排序,加入reverse则进行从大到小进行排序 print(a)
18、多维列表
a=[1,2,3,4,5] multi_dim_a=[[1,2,3],[123,312,4],[12,43,1]] print(multi_dim_a[1][1]) #使用[][]进行索引
19、字典 使用大括号
d={'apple':1,'pear':2,'orange':3} #冒号前面的为key,后面的为内容,字典的key唯一,如果不唯一则记住后面的元素,其不能是列表,以保证其唯一性要求 print(d['apple']) #打印字典的值 del d['pear'] #从字典中删除元素 d['b']=20 #加入元素到字典 print(d) #因为字典采用hash存储,所以字典是一个无序的容器
20、import模块
#方法一: # import time #直接使用模块名进行后续操作 # print(time.localtime()) # 方法二: # import time as t #如果模块名太长可以使用简称 #方法三: # from time import localtime 只引入模块的某个功能 # print(localtime()) #如果使用本方法,可以不用写time.localtime,而直接写localtime() #方法四: from time import * #加*可以结束 print(localtime())
21、引入自己的模块
# 确保自己的模块(同为.py文件)和本文件在同一个目录下, # import m1 #自己的模块名,其中定义了函数 # m1.function() 直接调用其函数即可,在macox中,其包目录在site-package中,如果将自建模块放入其中,则可以直接调用
22、break&continue
a=True while a: b=input('Please enter something:') if b!='': print('enter is not blank') break
23、错误处理
try: File=open('12','r') except Exception as e: print('there is no file named 12') response=input('do you want to creat a new file?(Y/N)') if response =='y'or'Y': #逻辑运算符 或or 且and 非not print('the file is created') else: pass #跳过
24、zip(将两个列表合并为一个列表项) lambda map
a=[1,2,3] b=[4,5,6] list(zip(a,b)) #zip返回为一个对象,如果想将其可视化,需要将其转化为list进行合并 for i,j in zip(a,b): print(i/2,j/2) #生成一个迭代器进行输出 fun1=lambda x,y:print(x+y) fun1(2,3) def fun1(x,y): return(x+y) #实现参数绑定 print(fun1,[1,3],[2,8])
25、shallow copy &deep copy
import copy a=[1,2,3] b=a print(id(a)) #输出变量的唯一id,是赋值,b只是将a的地址进行了复制,而没有进行实际的变量值的拷贝 print(id(b)) c=copy.copy(a) print('id of a:',id(a)) print('id of c:',id(c)) #浅拷贝,id不同,第一层空间地址不同,但是第二层空间(数组第二围)开始地址相同 d=copy.deepcopy(a) print('id of a:',id(a)) print('id of c:',id(d)) #深拷贝,id不同,从第一层空间开始地址已经完全不同
# 26、threading 线程
# 27、multiprocessing 多核心
# 28、tkinter GUI界面
29、pickle 保存代码
import pickle # a_dic={'fruit':['apple','pear'],'vegetable':['tomato','cumcuber']} # file =open('pickle_exm.pickle','wb') # pickle.dump(a_dic,file) # file.close() # file=open('pickle_exm.pickle','rb') # a_dic=pickle.load(file) #将之前保存的代码打开 # file.close()
#或者自动关闭方案
with open('pickle_exm.pickle','rb') as file: a_dic=pickle.load(file)
30、使用set寻找不同
char_list=['a','b','c','c'] print(set(char_list)) #使用set进行不同查找,输出结果为非重复序列,按hash排序 sentence='welcome to shijiazhuang' print(set(sentence)) #可以分辨句子中的不同字母,并以单个的形式呈现
# 31、正则表达式(待补充)
import re #引入正则表达式 pattern1="cat" pattern2='dog' string="dog runs to cat" print(pattern1 in string) #使用in来判断单词是否在目标语句中 #查找 print(re.search(pattern1,string))#使用正则表达式进行查找,查找到的内容会被以对象的形式返回 #匹配多种可能——使用[] print(re.search(r"r[A-Z0-9]n",'dog runs to the cat'))
原文地址:http://blog.51cto.com/xuan97916/2083958