1. 列表、元组操作

names = ['Alex',"Tenglan",'Eric']

>>> names[0]

>>> names[2]
>>> names[-1]
>>> names[-2#还可以倒着取
 
切片:取多个元素

>>> names[1:4] #取下标1至下标4之间的数字,包括1,不包括4

>>> names[1:-1] #取下标1至-1的值,不包括-1

>>> names[0:3] 

>>> names[:3] #如果是从头开始取,0可以忽略,跟上句效果一样

>>> names[3:] #如果想取最后一个,必须不能写-1,只能这么写

>>> names[3:-1] #这样-1就不会被包含了

>>> names[0::2] #后面的2是代表,每隔一个元素,就取一个

>>> names[::2] #和上句效果一样

追加

names.append("我是新来的")

插入

>>> names.insert(2,"强行从Eric前面插入")

>>> names

['Alex', 'Tenglan', '强行从Eric前面插入', 'Eric', 'Rain', 'Tom', 'Amy', '我是新来的']

修改

>>> names[2] = "该换人了"

>>> names

['Alex', 'Tenglan', '该换人了', 'Eric', 'Rain', '从eric后面插入试试新姿势', 'Tom', 'Amy', '我是新来的']

删除

>>> del names[2] 

>>> names.remove("Eric") #删除指定元素

>>> names.pop() #删除列表最后一个值

扩展

>>> names = ['Alex', 'Tenglan', 'Rain', 'Tom', 'Amy']

>>> b = [1,2,3]

>>> names.extend(b)

>>> names

['Alex', 'Tenglan', 'Rain', 'Tom', 'Amy', 1, 2, 3]

拷贝

>>> names = ['Alex', 'Tenglan', 'Rain', 'Tom', 'Amy', 1, 2, 3]

>>> name_copy = names.copy()

>>> name_copy = copy.copy(names)

>>> name_copy = copy.deepcopy(names)

统计

>>> names

['Alex', 'Tenglan', 'Amy', 'Tom', 'Amy', 1, 2, 3]

>>> names.count("Amy")

2

排序&翻转

>>> names

['Alex', 'Tenglan', 'Amy', 'Tom', 'Amy', 1, 2, 3]

>>> names.sort() #排序

TypeError: unorderable types: int() < str()

#3.0里不同数据类型不能放在一起排序了

>>> names.reverse() #反转

>>> names

['Tom', 'Tenglan', 'Amy', 'Amy', 'Alex', '3', '2', '1']

获取下标

>>> names = ['Tom', 'Tenglan', 'Amy', 'Amy', 'Alex', '3', '2', '1']

>>> names.index("Amy")

2 #只返回找到的第一个下标

2.元组

names = ("alex","jack","eric")

只有2个方法,一个是count,一个是index

2. 字符串操作 

'my name is {name} and age is {age}'.format_map({'name': 'alex', 'age': 33})

>>> n4.ljust(40,"-")

'Hello 2orld-----------------------------'

>>> n4.rjust(40,"-")

'-----------------------------Hello 2orld'

>>> s = "Hello World!"

>>> p = str.maketrans("abcdefg","3!@#$%^")

>>> s.translate(p)

'H$llo Worl#!

>>> b="ddefdsdff_" 

>>> b.isidentifier() #检测一段字符串可否被当作标志符,即是否符合变量命名规则

True

3. 字典操作

字典一种key - value 的数据类型,使用就像我们上学用的字典,通过笔划、字母来查对应页的详细内容。

info = {

'stu1101': "TengLan Wu",

'stu1102': "LongZe Luola",

'stu1103': "XiaoZe Maliya",

}

字典的特性:

1、无序的

2:key必须是唯一的,

增加

info["stu1104"] = "苍井空"

修改

info['stu1101'] = "武藤兰"

删除

info.pop("stu1101") #标准删除姿势

del info['stu1103']

info.popitem() #随机删除

查找

"stu1102" in info #标准用法

info.get("stu1102") #获取

info["stu1102"] #如果一个key不存在,就报错,get不会,不存在只返回None

Traceback (most recent call last):

File "<stdin>", line 1, in <module>

KeyError: 'stu1105'

多级字典嵌套及操作

av_catalog = {

"欧美":{

"www.youporn.com": ["很多免费的,世界最大的","质量一般"],

"www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],

"letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],

"x-art.com":["质量很高,真的很高","全部收费,屌比请绕过"]

},

"日韩":{

"tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","听说是收费的"]

},

"大陆":{

"1024":["全部免费,真好,好人一生平安","服务器在国外,慢"]

}

}

av_catalog["大陆"]["1024"][1] += ",可以用爬虫爬下来"

其他

info.values()

info.keys()

info.setdefault("stu1106","Alex")

info={'stu1102': 'LongZe Luola', 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'}

b = {1:2,3:4, "stu1102":"龙泽萝拉"}

info.update(b)

{'stu1102': '龙泽萝拉', 1: 2, 3: 4, 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'}

info.items()

dict.fromkeys([1,2,3],'testd')

{1: 'testd', 2: 'testd', 3: 'testd'}

循环dict 

#方法1

for key in info:

  print(key,info[key])

#方法2

for k,v in info.items(): #会先把dict转成list,数据里大时莫用

  print(k,v)

4.集合操作

集合是一个无序的,不重复的数据组合,

主要作用如下:

1、去重,把一个列表变成集合,就自动去重了

2、关系测试,测试两组数据之前的交集、差集、并集等关系

s = set([3,5,9,10]) #创建一个数值集合 

t = set("Hello") #创建一个唯一字符的集合 

a = t | s # t 和 s的并集 

b = t & s # t 和 s的交集 

c = t – s # 求差集(项在t中,但不在s中) 

d = t ^ s # 对称差集(项在t或s中,但不会同时出现在二者中) 



t.add('x') # 添加一项 

s.update([10,37,42]) # 在s中添加多项 

t.remove('H') 

len(s) 

x in s 

x not in s 

s.issubset(t) s <= t 测试是否 s 中的每一个元素都在 t 中 

s.issuperset(t) s >= t 测试是否 t 中的每一个元素都在 s 中 

s.union(t) s | t 返回一个新的 set 包含 s 和 t 中的每一个元素 

s.intersection(t) s & t 返回一个新的 set 包含 s 和 t 中的公共元素 

s.difference(t) s - t 返回一个新的 set 包含 s 中有但是 t 中没有的元素 

s.symmetric_difference(t) s ^ t 返回一个新的 set 包含 s 和 t 中不重复的元素 

s.copy() 返回 set “s”的一个浅复制

5. 文件操作

文件操作流程

1、打开文件,得到文件句柄并赋值给一个变量

2、通过句柄对文件进行操作

3、关闭文件

f = open('lyrics') #打开文件

first_line = f.readline() #读一行

print('我是分隔线'.center(50,'-'))

data = f.read()# 读取剩下的所有内容,文件大时不要用

f.close() #关闭文件

打开文件的模式有:

r,只读模式(默认)。

w,只写模式。【不可读;不存在则创建;存在则删除内容;】

a,追加模式。【可读; 不存在则创建;存在则只追加内容;】

"+" 表示可以同时读写某个文件

r+,可读写文件。【可读;可写;可追加】(从开头覆盖原有数据)

w+,写读   (数据被清空)

a+,同a   

"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)

rU

r+U

"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)

rb

wb

ab

with语句

with open('log','r') as f:

with open('log1') as obj1, open('log2') as obj2:

6. 字符编码与转码

python2

#-*-coding:utf-8-*-

import sys

print(sys.getdefaultencoding())

msg = "我爱北京天安门"

msg_gb2312 = msg.decode("utf-8").encode("gb2312")

gb2312_to_gbk = msg_gb2312.decode("gbk").encode("gbk")

python3

#-*-coding:gb2312 -*- #这个也可以去掉

import sys

print(sys.getdefaultencoding())

msg = "我爱北京天安门"

#msg_gb2312 = msg.decode("utf-8").encode("gb2312")

msg_gb2312 = msg.encode("gb2312") #默认就是unicode,不用再decode,喜大普奔

gb2312_to_unicode = msg_gb2312.decode("gb2312")

gb2312_to_utf8 = msg_gb2312.decode("gb2312").encode("utf-8")

python学习-1-列表,元组,字典,集合,文件操作的更多相关文章

  1. python3笔记十八:python列表元组字典集合文件操作

    一:学习内容 列表元组字典集合文件操作 二:列表元组字典集合文件操作 代码: import pickle  #数据持久性模块 #封装的方法def OptionData(data,path):    # ...

  2. Python列表,元组,字典,集合详细操作

    菜鸟学Python第五天 数据类型常用操作及内置方法 列表(list) ======================================基本使用====================== ...

  3. python中列表 元组 字典 集合的区别

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...

  4. **python中列表 元组 字典 集合

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...

  5. python_列表——元组——字典——集合

    列表——元组——字典——集合: 列表: # 一:基本使用# 1.用途:存放多个值 # 定义方式:[]内以逗号为分隔多个元素,列表内元素无类型限制# l=['a','b','c'] #l=list([' ...

  6. python的学习笔记01_4基础数据类型列表 元组 字典 集合 其他其他(for,enumerate,range)

    列表 定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素 特性: 1.可存放多个值 2.可修改指定索引位置对应的值,可变 3.按照从左到右的顺序定义列表元素,下标从0开始顺序访问 ...

  7. Python基础2 列表 元祖 字符串 字典 集合 文件操作 -DAY2

    本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...

  8. PYTHON 学习笔记3 元组、集合、字典

    前言 在上一节的学习中.学习了基本的流程控制语句,if-elif-else for while 等,本节将拓展上一节学习过的一些List 列表当中操作的一些基本方法,以及元祖.序列等. 列表扩展 我们 ...

  9. Python 列表&元组&字典&集合

    列表(list) 有序性,可存储任意类型的值 通过偏移存取,支持索引来读取元素,第一个索引为0 ,倒数第一个索引为-1 可变性 ,支持切片.合并.删除等操作 可通过索引来向指定位置插入元素 可通过po ...

  10. python 中列表 元组 字典 集合的区别

    先看图片解释 (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计过去一周我们买过的东西,把这些东西列出来,就是清单.由于我们买一种东西可能不止一次,所以清单中是允许有重复 ...

随机推荐

  1. urllib urllib2

    #-*-coding:utf-8-*- import urllib import urllib2 import cookielib ##urllib url="http://www.qq.c ...

  2. java中native方法的使用

    在非常多情况下,java须要调用其它语言的代码,比方c的代码.那么这个时候java中native方法就发挥作用了.以下就介绍native方法的使用. 一.JNI使用流程 a.编写带有native声明的 ...

  3. Objective-C中的关联(objc_setAssociatedObject,objc_getAssociatedObject,objc_removeAssociatedObjects)

    关联的概念 所谓的关联,字面意思是把两个相关的对象放在一起,实际也是如此.把两个对象相互关联起来,使得其中的一个对象成为另外一个对象的一部分,这就是关联. 关联的作用 使用Category,我们可以给 ...

  4. Asp.net MVC 插件式应用框架

    Asp.net MVC 插件式应用框架 2013年05月13日 10:16供稿中心: 互联网运营部 摘要:这几年来做了很多个网站系统,一直坚持使用asp.net mvc建站,每次都从头开始做Layou ...

  5. Android:使用ZXing生成二维码(支持加入Logo图案)

    ZXing是谷歌的一个开源库.能够用来生成二维码.扫描二维码.本文所介绍的是第一部分. 首先上效果图: ZXing相关各种文件官方下载地址:https://github.com/zxing/zxing ...

  6. ISE封装IP

    1.综合成ngc文件,然后再黑盒调用,再写一个端口文件(写个空壳文件,就是定义输入输出,在工程里面调用这个文件就行,把ngc放到工程目录下).

  7. tornado 初学

    tornado第一个例子 import tornado.ioloopimport tornado.web class MainHandler(tornado.web.RequestHandler): ...

  8. 自动清理DataGuard备机日志

    >> from zhuhaiqing.info #!/usr/bin/bash #删除DataGuard备机归档日志备份 export ORACLE_HOME=/opt/oracle/pr ...

  9. linux pptp 服务端安装并正常上网

    linux 下 PPTP VPN 1.安装相关软件32位版:yum -y install ppprpm -Uvh http://poptop.sourceforge.net/yum/stable/rh ...

  10. 调整jvm内存

    1.使用解压tomcat     在catalina.bat的第一行增加:    set JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNew ...