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 
  

6、if-else语句

if xy")

7、if-elif-else

if xy")

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'))