python快速入门课堂笔记_【机器学习】Python 快速入门笔记

Python 快速入门笔记

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

print("x is less than y")

6、if-else语句if x

print("x

else:

print("x>y")

7、if-elif-elseif x

print("x

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、inputa_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&continuea=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 mapa=[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 copyimport 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'))

你可能感兴趣的:(python快速入门课堂笔记)