python笔记

                        python笔记 - day3                        

参考:http://www.cnblogs.com/wupeiqi/articles/5453708.html

set特性:

  1.无序
  2.不重复
  3.可嵌套

函数:

  函数的作用:函数就是封装某一个功能的;

    1.def声明函数
    2.要有一个函数名
    3.函数体
    4.返回值,return返回值,如果不定义返回0
  5.定义函数,函数体不执行;调用函数,函数体内容才会执行

函数语法:

def  t1():  形式参数
print("aa")
t1() 实际参数

参数类型:

1.普通参数
2.默认参数 (必须放到参数列表的最后)
3.指定参数(将实际参数赋值给指定的形式参数)
4.动态参数:
        *  默认传入的参数,全部放置在元组中;
        **默认传入的参数,全部放置在字典中
5.万能参数   
   *args,**kwargs

变量:

全局变量,所有作用域都可读;
对全局便令进行{重新赋值},需要global;
特殊全局变量:列表。字典,可修改,不可重新赋值;
以后定义全局变量,变量名都要大写,潜规则;
 

函数应用示例:

例一:
【形式参数:*args,把传入的参数都会以元组的形式打印出来;也会把列表当成一个元素传入到元组里
def f1(*args): print(args,type(args)) f1(11,22,44,'alex') li = [11,22,'alex','hhh'] f1(li,12)
【实际参数:*,把列表里面的元素传入到元组里面
f1(*li)

实际参数:*,把字符串的每一个元素传入到元组里面】 li
= "name" f1(*li)
例二:
【**args两个*输出的数据类型为字典,所以传入的参数也必须为两个值】 def f1(
**args): print(args,type(args)) f1(n1="alex",n2=18 )
【kk为字典的key,定义的dic为字典kk的value】 dic
= {'k1':'v1','k2':'v2'} f1(kk=dic)
【**,把dic字典,以字典形式赋值给args并打印出来】 f1(
**dic)
【万能参数,前面是数组,后面是列表】 def f1(
*args,**kwargs): print(args) print(kwargs) f1(11,22,33,44,k1='v1',k2='v2') 【python传参数传的是引用当前变量,不是重新赋值一份】 def f1(a1): a1.append(999) li = [11,22,33,44] f1(li) print(li) 【全局变量,变量名用大写】 name = 'alex' def f1(): global name #全局变量,变量名用大写 name = 'freddy' age = 18 print(age,name) def f2(): age = 19 print(age,name) f1() f2()

函数:发送邮件,并判断是否成功:

例一,没有传参:
def sendmail ():
try:
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr

msg = MIMEText('test mail', 'plain', 'utf-8')
msg['From'] = formataddr(["武沛齐",'wptawy@126.com'])
msg['To'] = formataddr(["走人",'1011464647@qq.com'])
msg['Subject'] = "主题"

server = smtplib.SMTP("smtp.126.com", 25)
server.login("wptawy@126.com", "WW.3945.59")
server.sendmail('wptawy@126.com', ['1011464647@qq.com',], msg.as_string())
server.quit()
except:
return False
else:
return True
res = sendmail()
if res == False:
print("Send mail Fail.")
else:
print("Send mail Seucess.")


例二,带传参:1.收件人 2.邮件内容 3.默认参数:
def sendmail (xxoo,content,xx="OK"):
print(xxoo,content,xx)
try:
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr

msg = MIMEText(content, 'plain', 'utf-8')
msg['From'] = formataddr(["武沛齐",'wptawy@126.com'])
msg['To'] = formataddr(["走人",'1011464647@qq.com'])
msg['Subject'] = "主题"

server = smtplib.SMTP("smtp.126.com", 25)
server.login("wptawy@126.com", "WW.3945.59")
server.sendmail('wptawy@126.com', [xxoo,], msg.as_string())
server.quit()
except:
return False
else:
return True
res = sendmail('1011464647@qq.com',"sb")
if res == False:
print("Send mail Fail.")
else:
print("Send mail Seucess.")


例3:进阶,手动输入收件人邮件地址;
def sendmail (xxoo,content,xx="OK"):
print(xxoo,content,xx)
try:
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr

msg = MIMEText(content, 'plain', 'utf-8')
msg['From'] = formataddr(["武沛齐",'wptawy@126.com'])
msg['To'] = formataddr(["走人",'1011464647@qq.com'])
msg['Subject'] = "主题"

server = smtplib.SMTP("smtp.126.com", 25)
server.login("wptawy@126.com", "WW.3945.59")
server.sendmail('wptawy@126.com', [xxoo,], msg.as_string())
server.quit()
except:
return False
else:
return True
while True:
em = input("mail addr:")
result = sendmail(em,"SB")
#传入时间参数,em:收件人地址;SB,是邮件内容;
# result = sendmail(xxoo=em,content="SB")
#指定参数,
if result == 'False':
print('send mail fail.')
else:
print('send mail secuess')


 函数:以函数的形式写代码示例:

readme:

1.这个程序包含一个主程序文件,一个存放账号密码的文件;

2.存放密码的文件,账号和密码的分隔符为“|”

主程序:

 1 #!/usr/bin/python env
 2 #_*_coding:utf-8 _*_
 3 
 4 def login(username,password):
 5     """
 6     用于用户登陆
 7     :param username: 用户输入的用户名
 8     :param password: 用户输入的密码
 9     :return: Ture,登陆成功;False,登陆失败;
10     """
11     f = open('db','r+')
12     for line in f.readlines():
13         line = line.split("|")
14         if line[0] == username and line[1] == password:
15             return True
16     return False
17 
18 
19 def register(username,password):
20     """
21     用于用户注册
22     :param username: 注册用户名
23     :param password: 注册用户密码
24     :return:  默认None
25     """
26     f = open('db','a')
27     temp = "
" + username + "|" + password
28     f.write(temp)
29     f.close()
30 
31 
32 def main():
33     t = input("1,login  2.register:")
34     if t == '1':
35         user = input("user:")
36         pwd = input("passwd:")
37         r = login(user,pwd)
38         if r == True:
39             print("login secuess")
40         else:
41             print("login fail")
42     elif t == '2':
43         user = input("user:")
44         pwd = input("passwd:")
45         register(user,pwd)
46 main()

语法糖:

【三元运算,三目运算】
1.正常写法:
if 1 == 1:
    name = "freddy"
else:
    name = "SB"
思路:
    1.先判断条件,如果1=1,name就等于freddy,
    2.否则,name就等于SB;

2.三目写法:
name = "freddy" if 1 == 1 else "SB"
print(name)
思路:
    1.我想要name等于freddy,想要达到什么条件,
    2.否则,就是SB;

【lambda,】
1.正常写法:
def t1(a1):
    return a1 +100
res = t1(10)
print(res)

2.lambda写法:
f2 = lambda a1: a1 +110
ret = f2(10)
print(ret)
语法解析:
  1.f2 = lambda #函数名+lambda
  2.a1 #形式参数
  3. a1 + 100 #函数内执行主体内容
2.1.之lambda + 2个函数: f2 = lambda a1,a2: a1 + a2 +110 ret1 = f2(10,1) print(ret1) 2.2.之lambda + 2个函数 + 默认参数: f2 = lambda a1,a2=2: a1 + a2 +110 ret2 = f2(10) print(ret2)

内置函数:

【abs,绝对值】
n = abs(-1)
print(n)

【bool,】
print(bool(1))
结果:True
print(bool(" "))
结果:True
print(bool())
结果:False
print(bool(0))
结果:False
print(bool(None))
结果:False
print(bool([]))
结果:False

【all(),所有为Ture,才为真;】
【可以被迭代,循环的对象】
n = all([1,2,3,4])  
print(n)

【any(),只要有一个为真就是真】
n = any([1,[],0,"",None])
print(n)

【bin(),把5转换成2进制】
print(bin(5))
结果:0b101  #0b表示转成的是2进制
【oct(),把9转换成8进制】
print(oct(9)) 结果:0o11 #0o表示是8进制
【hen(),把15转换成16进制】
print(hex(15)) 结果:0xf  #0x表示是16进制
【bytes(),字符串转换成字节】 s
= '胜伟' n = bytes(s,encoding="utf-8") print(n) n = bytes(s,encoding="gbk") print(n) 【str(),把字节转换成字符串用str】 nn = str(bytes("胜伟",encoding="utf-8"),encoding="utf-8") print(nn)

函数默认没有返回值,返回None
li = [11,22,33,44]
def f1(arg):
arg.append(55)
li = f1(li) #让li重新等于了函数的返回值None
print(li)

结果:None


li = [11,22,33,44]
def f1(arg):
arg.append(55)
return arg #增加了return
li = f1(li)
print(li)
结果:[11, 22, 33, 44, 55]
li = [11,22,33,44]
def f1(arg):
arg.append(55)
f1(li)  #直接打印li的值
print(li)
结果:[11, 22, 33, 44, 55]
bytes:把“唐胜伟”转换成utf-8的格式】
s = "唐胜伟"
ss = bytes(s,encoding='utf-8')
print(ss)
前言:在ASSCII码表中,第65位是大写字母A;
【chr:把ASCII数字转换成字母】
r = chr(65)
print(r)
结果:A

【ord:把大写字母A,转换成ASCII对应的数字】
a = ord("A")
print(a)

结果:65
【compile:就是把字符串编译成python代码】
exec:执行python代码】
s = "print(123)"
r = compile(s,"<string>","exec")
exec(r)
eval:把字符串通过evel转成python代码来执行】
s = "8*8"
ret = eval(s)
print(ret)
总结:
exec():能执行python所有的东西;
eval():只能执行python表达式,并且evel有返回值;
exec():执行python代码,或者字符串;
eval():执行表达式,并返回结果;


【dir():dir():获取python内置方法的功能】
print(dir(list))
help(list)
divmod:取商和余数,在做分页的时候使用】
r = divmod(100,10)
print(r)

print(r[0])
print(r[1])

r1,r2 = divmod(100,5)
print(r1,r2)
【isinstance:判断对象是否是某个类的实例】
【例:判断对象s是否是str类的实例】
s = "alex"
r = isinstance(s,str)
print(r)
filter:取出列表中大于22的值】
原理:内部实现机制:li的每个参数都会执行f2方法,如果条件成立,返回Ture,并把结果赋值给result,返回False不做处理;

例一,不使用filter:
def f1(args):
result = []
for item in args:
if item > 22:
result.append(item)
return result
li = [11,22,33,44,55]
ret = f1(li)
print(ret)



例二,使用filter:
def f2(a):
if a>22:
return True
li = [11,22,33,44,55]
result = filter(f2,li)
#filter(函数,可迭代的对象)
print(list(ret))


lambdalambda会内部做返回值,结果是什么就会返回什么】
f1 = lambda a: a > 30
ret = f1(90)
print(ret)

结果:True

filter+lambda:如果返回True,则把结果赋值给result】
li = [11,22,33,44,55]
result = filter(lambda a: a >33,li)
print(list(result))

结果:[44, 55]

【map:需求,每个元素加100
[map语法:map(函数,可迭代的对象(可以for循环的东西))]
方法一,原始方法:
li = [11,22,33,44,55]
def f1(args):
result = []
for i in args:
result.append(100+i)
return result
r = f1(li)
print(r)



方法二,进阶:
li = [11,22,33,44,55]
def f2(a):
return a + 100
result = map(f2,li)
print(list(result))
方法三,map+lambda:
li = [11,22,33,44,55]
result = map(lambda a: a+ 100,li)
print(list(result))
总结:
filter: 函数返回Ture,将元素添加到结果中;
map: 将函数返回值添加到结果中;


【globals():全局变量,locals(),局部变量

NAME='Freddy'
def show():
a = 123
c = 123
print(locals())
print(globals())
show()
hash:给传入的对象,转换成hash值,不管你传入的值是多长,hash出来值得长度永远是固定的】
【应用场景:一般都用于成字典的key】
s = 'feawfefeafefafwseesfesfsefwa'
print(hash(s))
【len:】
f = "唐胜伟"
b = len(bytes(f,encoding='utf-8'))
print(len(f))
print(b)


总结:
len:在python3里面,len的结果就是3,python3中用字符来计算的;
在python2中,len的结果就是9,python2中是用字节来计算的;
max取出来最大的值
r = max([11,22,88,55])
print(r)


【min:取出来最小的值
r = min([11,22,88,55])
print(r)
sum求和
r = sum([11,22,88,55])
print(r)
reversed反转显示结果】
li = [11,22,44,33]
r = reversed(li)
print(list(r))
round四舍五入
r = (1.8)
print(r)

结果:2

r = round(1.4)
print(r)

结果:1

【zip:取值方法】
l1 = ['freddy',11,22,33]
l2 = ['is',11,22,33]
l3 = ['sb',11,22,33]

tem = zip(l1,l2,l3)
print(list(tem))

结果:[('freddy', 'is', 'sb'), (11, 11, 11), (22, 22, 22), (33, 33, 33)]

例二:
l1 = ['freddy',11,22,33]
l2 = ['is',11,22,33]
l3 = ['sb',11,22,33]

tem = zip(l1,l2,l3)
* 使用zip进行格式化输出;

tmp = list(tem)[0]
print(tmp)
('freddy', 'is', 'sb')
* 取出序列化的第一列

ret = ' '.join(tmp)
print(ret)
结果:
freddy  is  sb



文件操作:

【r,只读】
f =open('db','r')

【w,清空原来db文件,然后再写入新内容】
f =open('db','w')

【x,文件存在报错,不存在,创建并写内容】
f =open('db','x')

【a,追加内容】
f =open('db','a')

【ab,追加写入;bytes,字节编码写入至文件内】
f = open("db",'ab')
f.write(bytes("胜伟",encoding="utf-8"))
f.close()

【读文件方法:1.utf-8。2.GBK。】
f = open('db','r',encoding='utf-8')  #如果文件是以'utf-8'方式保存的,这里就要写一个'utf-8';
f = open('db','r',encoding='GBK')   #如果文件是以gbk方式保存的,这里就要写一个GBK;
res = f.read()
print(res)
f.close()

【直接以二进制方式打开文件,优点:1.跨平台。2.快。】
f = open('db','rb')
data = f.read()
print(data,type(data))


【如果想以二进制的形式写入文件,写入的内容也必须转成二进制格式】
f = open('db','xb')
f.write(bytes('唐胜伟',encoding='utf-8'))
f.close()
加b,以二进制,字节方式读
f = open('db','rb')
res = f.read()
f.close()
print(res,type(res))
结果:b'xe5x94x90xe8x83x9cxe4xbcx9f' <class 'bytes'>

【以字符串的方式读】
f = open('db','r',encoding='utf-8')
res = f.read()
f.close()
print(res,type(res))
结果:唐胜伟 <class 'str'>


【seek(),永远找的是字节指针位置,一个字母一个字节,一个汉字,如果是utf-8的格式,是三个字节
f = open('db','r+',encoding="utf-8")
data=f.read(1)  #f.read(1):如果以r的方式打开,读取就是一个字符指针位置;如果以rb的方式打开,读取就是一个字节指针位置
print(data)
f.seek(1)  #seek(),调整指针的位置,seek的时候,seek的永远是字节的指针位置
f.write("777")
f.close()
【tell:获取当前指针的位置,单位永远是字节】
f = open('db','r+',encoding="utf-8")
data=f.read(1)
print(f.tell())  #f.tell():获取当前指针的位置,结果是:3,因为一个汉字(字符)占3位;
f.seek(f.tell())  #在tell获取的位置开始写内容,向后覆盖;
f.write("777")
f.close()

【读出来的文件类型是,字符串】
f=open('db','r',)
data = f.read()
print(data,type(data))
结果:<class 'str'>
f=open('db','r',encoding='utf-8')
data = f.read()
print(data,type(data))
结果:<class 'str'>

【rb,以字节方式读,读取类型是 字节】
f=open('db','rb',)
data = f.read()
print(data,type(data))

结果:<class 'bytes'>
有b,按照字节读取;无b,按照字符读取
f = open('db','r+',encoding='utf-8')

tell(),获取当前指针位置
seek(1) 跳转到指定指针位置
data = f.read(1)  #tell当前指针所在的位置(字节)
print(f.tell())   #调整当前指针的位置(字节)
f.seek(f.tell())   #当前指针位置开始向后覆盖
f.write('777')   # write() 写数据,有b,写字节,没b,写字符;

write()
【flush,把缓冲区内容写入硬盘】
文件1:
f = open('db','a')
f.write("123")
f.flush()
input("str:")

文件2:
f =open('db','r+')
ret = f.read()
print(ret)

readable,判断是否可写
f = open('db','w')
ret = f.readable()
print(ret)

readline,一行一行读,避免读取数据过大
f = open('db','r')
f.readline()
f.readline()

【truncate,截断数据,把指针位置后的数据清空】
f = open('db','r+',encoding='utf-8')
f.seek(3)
f.truncate()
f.close()


【一行,一行的读这个文件】
f = open('db','r+',encoding="utf-8")
for line in f:
print(line)


【with,优点:不用手动去关闭文件,代码块的代码执行完后会自动关闭文件(f.close)】
思路一:
把f1文件里面的内容全部写入到f2:
with open('db1','r',encoding='utf-8') as f1,open('db2','w',encoding='utf-8') as f2:
for line in f1:
f2.write(line)
【把db1的前10行内容写入到db2文件中】
with open('db','r',encoding='utf-8') as f1,open('db1','w',encoding='utf-8') as f2:
count = 0
for line in f1:
count +=1
if count <= 10:
f2.write(line)
else:
break
思路二:
【把db1文件中的freddy,替换成st】
with open('db1','r',encoding='utf-8') as f1,open('db2','w',encoding="utf-8") as f2:
for line in f1:
new_str = line.replace("freddy",'st')
f2.write(new_str)

 

验证码小程序:

【例1:生成6位字母验证码】
import random
li = []
for i in range(6):
    temp = random.randrange(65,91)
    c = chr(temp)
    li.append(c)

例二验证码,程序带入: 【join的时候元素必须都是字符串】 result
= "".join(li) print(result)
【例二:生成6位,包含两个数字的验证码】
import random li = [] for i in range(6): r = random.randrange(0,5) print(r) if r == 2 or r == 4: num = random.randrange(0,10) li.append(str(num)) ##转换成字符串类型,否则不能join else: temp = random.randrange(65,91) c = chr(temp) li.append(c) result = "".join(li) print(result)

从作业中学到的知识:

【语法技巧】
if True:
print('aa')
tt = True
if tt:
print('aa')


【列表格式的字符串】 s
= "[11,22,33,44,55]" print(s,type(s)) 结果:<class 'str'> 【json:数据序列化,跨平台传输数据】 import json s = "[11,22,33,44,55]" n = json.loads(s) print(n,type(n)) 结果:<class 'list'> #json:将指定格式的字符串,转换成python的基本数据类型, #注意:字符串形式的字典{"k1":"v1"}的内部字符串必须是双引号; 【json:格式化输出】 import json r = input("input dic:") dic = json.loads(r) bk = dic['backend'] rd = "server %s %s weight %d maxconn %d"%(dic['record']['server'], dic['record']['server'], dic['record']['weight'], dic['record']['maxconn']) print(bk) print(rd) 输入内容:{"backend": "test.oldboy.org","record":{"server": "100.1.7.9","weight": 20,"maxconn": 30}}

 函数重要性:

原文地址:https://www.cnblogs.com/tangshengwei/p/5626978.html