本章是学习前文提到的工具书《Python学习手册》针对基本数据类型的一个总结。
Python基本数据类型
data:image/s3,"s3://crabby-images/ccb9f/ccb9feb068d0f4ae2e6b4da63a1098b97f03667d" alt=""
data:image/s3,"s3://crabby-images/11c9d/11c9d2f5a379f1197edceb39e775d8a3f538223a" alt=""
数字
len(); //取长度
pow,abs,round int hex oct bin ;
oct函数把十进制数转换为八进制,hex函数把十进制数转换为十六进制,而bin把十进制数转换为二进制
str() repr();
math.pi math.e; math.sqrt(81);//开平方根
random.random() //随机数字生成器
random.choice() //随机选择器
表达式是处理数字的最基本的工具
Python表达式操作符
data:image/s3,"s3://crabby-images/02ff3/02ff369b7484553299074da8c33ac71cbc2dd139" alt=""
data:image/s3,"s3://crabby-images/2a77a/2a77af580870346f17f019f8ae5045750014e0bc" alt=""
集合
x=set('spam');x={'s','p','a','m'};
y={'h','a','m'};
x&y={'a','m'}; x|y={'a','p','s','h','m'};
x-y={'p','s'}
data:image/s3,"s3://crabby-images/7dd50/7dd50e25832246bebc552be0fd53d3267536a52f" alt=""
其它类型: 复数,小数数字,分数类型,布尔值,占位符None
字符串
基本操作有合并,分片,索引等。
data:image/s3,"s3://crabby-images/cadda/caddace7486fb2684de0ccf4fa1e1f3aa552321c" alt=""
(是序列) 索引:S='spam'; S[0]='s',S[3]='m'; S[-1]='m',S[-2]='a';
分片:S[1:]='pam',S[0:3]='spa';
data:image/s3,"s3://crabby-images/00448/004488e0eb6fdcaf6c87263631687831bf169444" alt=""
加法=合并 S+'xyz'='spamxyz',S*4='spamspamspamspam'
S.find('pa')=1 返回偏移; S.replace('pa','XYZ')='sXYZm';
S.upper()='SPAM'; //lower
S.isalpha()=True; //isdigit
line= 'aaa,bbb,ccc,dd'
line.splite(',')=['aaa','bbb','ccc','dd'];
line.rstrip();//移除右边的空格
格式化 '%s,eggs,and %s' %('spam','SPAM!') ='spam,eggs,and SPAM!'
'{0},eggs,and {1}'.format('spam','SPAM!')='spam,eggs,and SPAM!'
更高级的字符串格式化
1、基于字典的字符串格式化
data:image/s3,"s3://crabby-images/b3204/b3204a3605139d51110157b6bbd04c22276762b9" alt=""
2、添加键、属性和偏移量
data:image/s3,"s3://crabby-images/74425/7442578971a8e8eb8aa8f9edd11d0372cc64cdc9" alt=""
data:image/s3,"s3://crabby-images/215d5/215d501b24c378d684e521f283939a8a0d995668" alt=""
补充:list(map(sum,M)) //map()函数对传入的list的每一个元素进行映射,返回一个新的映射之后的list
map()是 Python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回。又如:
data:image/s3,"s3://crabby-images/38de4/38de48d5605008f3eb51d1c1ec4c646ce73cc40d" alt=""
data:image/s3,"s3://crabby-images/61869/61869d1ba858690d570947b471a78f96a803d673" alt=""
ord()函数是chr()函数(对于8位的ASCII字符串)或unichr()函数(对于Unicode对象)的配对函数,它以一个字符(长度为1的字符串)作为参数,返回对应的ASCII数值,或者Unicode数值,如果所给的Unicode字符超出了你的Python定义范围,则会引发一个TypeError的异常。
列表
(是序列) L=[123,'spam',1.23];len(L)=3; l[0]=123; L.index('spam')索引...
L.append('NI');L.extend([3,4,5]) ; L.insert(1,'toast');//插入 L.sort()排序;L.reverse()反转;
extend()和append()的区别:
data:image/s3,"s3://crabby-images/5edd4/5edd41fe8702b6aac172be1bb80848c2856717a0" alt=""
L=['spam','eggs','ham']
L.pop(1);L.remove('eggs');del L[0];del L[1:]
嵌套 M=[ [1,2,3],
[4,5,6],
[7,8,9]] ;M[0]=[1,2,3]; M[1][2]=6;
列表解析 col2=[row[1] for row in M]=[2,5,8];
[row[1]+1 for row in M]=[3,6,9];
[row[1] for row in M if row[1]%2==0]=[2,8];
[M[i][i] for i in [0,1,2]] = [1,5,9];
G=(sum(row) for row in M),next(G)=6,next(G)=15,next(G)=24;...生成器
list(map(sum,M))=[6,15,24];[ord(x) for x in 'spaam']={115,112,97,97,109}; ...生成列表
{sum(row) for row in M}={6,15,24}; ...生成集合
{i:sum(M[i]) for i in range(3)}={0:6,1:15,2:24};...生成字典
data:image/s3,"s3://crabby-images/6975d/6975d18d8a3eb0ac582b858db6e0284cb2521fd4" alt=""
data:image/s3,"s3://crabby-images/8a886/8a8860fd80798dd25d38ce307183ffeccc96561d" alt=""
字典
(是映射) D={'food':'spam','quantity':4,'color':'pink'}
D['food'] = 'spam';
D['quantity']+=1;D={'food':'spam','color':'pink','quantity':5}
D={};D['name']='Bob';D['job']='dev';D['age']=40;D={'age':40,'job':'dev','name':'Bob'}
嵌套 rec={'name':{'first':'Bob','last':'smith'},
'job':['dev','mgr'],
'age':40.5
}
键 D={'a':1,'b':2,'c':3};ks=list(D.keys())=['a','b','c'];
'f' in D = False
if not 'f' in D:
print('missing')
D={'spam':2,'ham':1,'eggs':3}
list(D.values())
输出:[3, 2, 1]
list(D.items())
输出: [('eggs', 3), ('spam', 2), ('ham', 1)]
D.get('spam');D.get('toast',88)
D2={'toast':4,'muffin':5};D.update(D2); D.pop('muffin')
data:image/s3,"s3://crabby-images/3e429/3e42937b78efd2cc70e9153935b87ad2d9fa111b" alt=""
data:image/s3,"s3://crabby-images/56d6c/56d6c0ebf039f575bf933ba1444d303fd30dab9b" alt=""
创建字典的四种方法:
data:image/s3,"s3://crabby-images/42010/42010c1f5ac7bdd9de6663cf1eb8dead7e55623e" alt=""
data:image/s3,"s3://crabby-images/678dd/678dd55870dc884f8166a41f8afef91537df408d" alt=""
data:image/s3,"s3://crabby-images/41d79/41d79e92a49519d50e4904cbe104e337d94318a2" alt=""
元组
(不可变的序列) T=(1,2,3,4);len(T)=4 ;T+(5,6)=(1,2,3,4,5,6);T[0]=1;
T.index(4)=3; T.count(4)=1;
T=('spam',3.0,[11,22,33]);
data:image/s3,"s3://crabby-images/7f005/7f0055778ba5fc7741b53a092f7f238f79449c6b" alt=""
data:image/s3,"s3://crabby-images/c3dec/c3deccaa526fab5ba4c150b33281972f1b5c6f55" alt=""
文件
f=open('data.txt','w');f.write('hello!\n');f.close();
f=file("/home/test/c.txt","r");
f.read();
date=open('data.bin','rb').read();
remove()/unlink() --- 删除文件
rename()/renames()---重命名文件
access()----------检验权限模式
chmod()-----------改变权限模式
chown()/lchown()-----改变 owner 和 group ID/功能相同, 但不会跟踪链接
umask()-------设置默认权限模式
open()---底层的操作系统 open (对于文件, 使用标准的内建 open() 函数)
read()/write()---根据文件描述符读取/写入数据
dup()/dup2()----复制文件描述符号,但是是复制到另一个文件描述符设备号
makedev()-----从 major 和 minor 设备号创建一个原始设备号
mkdir(path[,mode=0777])----创建目录
makedirs(name, mode=511)-----创建多层目录,
rmdir(path)------删除目录
removedirs(path)----删除多层目录
listdir(path)----列出指定目录的文件
getcwd() --- ---返回当前工作目录
chdir(path)-----改变当前工作目录
walk(top,topdown=True, onerror=None)---生成一个目录树下的所有文件名
chroot()----改变当前进程的根目录
data:image/s3,"s3://crabby-images/3de40/3de4026e9cb0cce63e0061a3fbe717012fd087e6" alt=""
网友评论