400 028 6601

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

python内置函数和序列化

修改字符集

全局修改

点击window
python内置函数和序列化

创新互联从2013年成立,先为辛集等服务建站,辛集等地企业,进行企业商务咨询服务。为辛集企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

针对某一个工程

右键,有一个属性propertes
python内置函数和序列化

给某个文件,也就是前面加

也是右键属性,这里就不在说了
#模块的和模块的常用方法


print range(10)
for item in xrange(10):
    print item
    #输出的时候并没有全部创建,他只是一个生成器,说明他没有写入内存中
    #也就是说每一次创建就只创建一个整数
def foo():
    yield 1
re = foo()
print re
输出:
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
0
1
2
3
4
5
6
7
8
9
def fool():
    yield 1
    yield 2
    yield 3
yield 4  
#他的执行过程是,第一从从yield 1 执行,下一次直接从yield2开始执行 
re = fool()
print re
#生成了一个生成器,每次遍历只生成一条
for item in re :
print item
结果:

1
2
3
4
def ReadLines():
    seek = 0
    while True:
        with open('E:/temp.txt','r') as f :
            f.seek(seek)
            date = f.readline()
            if date:
                seek = f.tell()
                yield date
            else:
                return 
print ReadLines()
for item in ReadLines():
    print item    

三元运算和lambda表达式

三元运算

#使用random生成验证码
它使用的是ascall的值进行生成的

import random
print random.random()
print random.randint(1,5)
#生成1-5之间的随机整数
print random.randrange(1,3)
#生成大于等于1,小于3的随机数
import random
code = []
for i in range(6):
    if i == random.randint(1,5):
        code.append(str(random.randint(1,5)))
    else:
        temp = random.randint(65,90)
        code.append(chr(temp))
print ''.join(code)

#注意:join和+=的区别
join效率更高,+=每次都要在内存中请求一块空间,join只申请一次

md5加密

#!/usr/bin/env python
#coding:utf-8
import hashlib
hash=hashlib.md5()
hash.update('admin')
print hash.hexdigest()
print hash.digest()
21232f297a57a5a743894a0e4a801fc3
!#/)zW��C�JJ�¬�
#md5不能反解

序列化和JSON

应用实例:(python 和python之间传输文件,单机游戏实时保存)

为什么要序列化?

一个程序将列表存在一个程序中,另一个程序使用这个文件的时候。使用序列化之后在让另一个程序去读取的话,使两个python程序之间内存数据之间的交换,两个独立的进程在内存中看,他们的内存空间不能互相访问,如果两个程序之间不仅仅只是简单的列表共享,还想其他数据交换,数据可能比较复杂。而且硬盘只能存字符串类型的数据,只能通过系列化,存入文件,另一个程序然后读取文件的内容,然后将其反序列化之后,在加载到内存中
序列化:把一个对象或(一个列表、字典),把对象通过Python特有的机制序列化,序列化就是以特殊的形式以过二进制的方式给对象加密,并且序列化之后可以反序列化。

序列化

import pickle
li = ['axex',11,22,'ok','sb']
print pickle.dumps(li)
print type(pickle.dumps(li))
输出结果:
(lp0
S'axex'
p1
aI11
aI22
aS'ok'
p2
aS'sb'
p3
a.

#是一个没有规则的字符串类型

反序列化

import pickle
li = ['axex',11,22,'ok','sb']
dumpsed = pickle.dumps(li)
print type(dumpsed)
loadsed = pickle.loads(dumpsed)
print loadsed
print type(loadsed)

['axex', 11, 22, 'ok', 'sb']

将列表序列化到一个文件中

import pickle
li = ['axex',11,22,'ok','sb']
pickle.dump(li,open('E:/temp.pk','w'))
result = pickle.load(open('E:/temp.pk','r'))
#将文件中反序列化

JSON:一种标准化的数据格式,把不同格式的数据JSON化。
##两种序列化的区别


新闻名称:python内置函数和序列化
网页URL:http://mzwzsj.com/article/iicgoc.html

其他资讯

让你的专属顾问为你服务