字典

字典四种创建方法:

1、

  1. dic = dict()
  2. print(dic)
  3. # 相当于
  4. dic1 = {}
  5. print(dic1)
  6.  
  7. # 输出
  8. {}
  9. {}

2、

  1. dic = dict(one=1, two=2)
  2. print(dic)
  3. # 输出
  4. {'one': 1, 'two': 2}

3、最常使用的定义字典方式

  1. dic1 = {'name': 'abc', 'age': 20}
  2. print(dic1)
  3.  
  4. # 输出
  5. {'name': 'abc', 'age': 20}

4、

  1. dic1 = dict((('name', 'abc'), ('age', 18)))
  2. print(dic1)
  3.  
  4. # 输出
  5. {'age': 18, 'name': 'abc'}

字典的copy(浅拷贝)

  1. acc1 = {'name': 'aaa', 'account': {'credit': 3000, 'balance': 3000}}
  2. acc2 = acc1.copy()
  3. acc2['name'] = 'ccc'
  4. print(acc1)
  5. print(acc2)

输出:从输出可以看出,acc2的名字发生了改变,但是其它没有变化

那我把acc2的列表里面内容改了呢?

  1. acc1 = {'name': 'aaa', 'account': {'credit': 3000, 'balance': 3000}}
  2. acc2 = acc1.copy()
  3. acc2['name'] = 'ccc'
  4. print('acc1_dic-->', acc1)
  5. print('acc2_dic-->', acc2)
  6.  
  7. acc2['account']['balance'] = 2500
  8. print('acc1_dic-->', acc1)
  9. print('acc2_dic-->', acc2)
  10.  
  11. print('acc1_dic-->', id(acc1['account']))
  12. print('acc2_dic-->', id(acc2['account']))

从输出可以看出,更改了acc2列表里面的内容,acc1列表里面的也自动更改了,同时通过对比2个字典里面列表位置可以看出,都是引用一个内存地址。

总结:

通过以上例子说明,浅拷贝只在第一层数据改变时候生效,当有第二层数据时候,就是引用了。

集合(set)

1、去重功能

  1. li = [1, 2, 3, 4, 5, 6, 2, 4, 5, ]
  2. s1 = set(li)
  3. print(s1)
  4.  
  5. # 输出
  6. {1, 2, 3, 4, 5, 6}

2、交集:取2个集合内共有部分

  1. s1 = {1, 2, 3, 4, 5}
  2. s2 = {2, 3, 6, 7}
  3.  
  4. print(s1 & s2)
  5. print(s1.intersection(s2)) # 另外一个写法
  6.  
  7. # 输出
  8. {2, 3}
  9. {2, 3}

3、并集:取2个集合内不同部分

  1. s1 = {1, 2, 3, 4, 5}
  2. s2 = {2, 3, 6}
  3.  
  4. print(s1 | s2)
  5. print(s1.union(s2)) # 另外一个写法
  6. # 输出
  7. {1, 2, 3, 4, 5, 6}

4、差集:属于集合A且不属于集合B

  1. s1 = {1, 2, 3, 4}
  2. s2 = {2, 3, 6, 8}
  3.  
  4. print(s1 - s2)
  5. print(s1.difference(s2)) # 另外一个写法
  6.  
  7. # 输出
  8. {1, 4}
  9.  
  10. s1 = {1, 2, 3, 4}
  11. s2 = {2, 3, 6, 8}
  12.  
  13. print(s2 - s1)
  14. print(s2.difference(s1)) # 另外一个写法
  15.  
  16. # 输出
  17. {8, 6}

5、对称差集:把2个交集内相同的去掉,取不同的内容

  1. s1 = {1, 2, 3, 4}
  2. s2 = {2, 3, 6, 8}
  3.  
  4. print(s1 ^ s2)
  5. print(s1.symmetric_difference(s2)) # 另外一个写法
  6.  
  7. # 输出
  8. {1, 4, 6, 8}

6、子集:就是包含,谁包含谁,如果s1所有元素包含s2所有元素,那么s2就是s1的子集

  1. s1 = {1, 2, 3, 4, 5}
  2. s2 = {1, 2, 3}
  3.  
  4. print(s1 <= s2)
  5. print(s1.issubset(s2)) # 另外一个写法
  6.  
  7. print(s2.issubset(s1))
  8.  
  9. # 输出
  10. False
  11. False
  12. True

7、父集:跟子集一样

  1. s1 = {1, 2, 3, 4, 5}
  2. s2 = {1, 2, 3}
  3.  
  4. print(s1 >= s2)
  5. print(s1.issuperset(s2)) # 另外一个写法
  6.  
  7. # 输出
  8. True
  9. True

文件操作(open)

文件操作主要使用open 及 with open语句进行文件操作。文件的打开,主要包含三步:

1、找到文件

2、打开文件(是用什么模式)

3、关闭文件

文件打开模式:

r: open for reading (default)

w: open for writing,truncating the file first

x: create a new file and open it for writing,if the file already exists,raises an `FileExistsError` (only python 3.x)

a: open for writing, appending to the end of the file if it exists

b: binary mode

+: open a disk file for updating (reading and writing)

r+: reading and writing 比较常用

w+: opens and truncates the file to 0 bytes 没啥卵用

a+: append

带b和不带b的区别:

1、读取上的区别,带b读取是字节,不带b读取是字符串。

2、如果在模式里面带b,encoding这个参数也不能使用了,代表你告诉python,不再需要你帮我处理,我直接跟二进制打交道,也就意味这,你拿到的数据是2进制的,写的时候也必须是2进制才可以。

so:你在写的时候需要把字符串转换为字节,才可以进行写入

  1. f = open('utf-8.txt', 'ab')
  2. f.write(bytes('陈', encoding='utf-8'))
  3. f.close()

文件基本操作方法:

通过TextIOWrapper类里面可以看见文件操作有哪些方法

1、read: 在文件比较大的时候不推荐使用,

这里的encoding编码意思是你告诉python你打开的时候是以什么编码方式打开,如果打开乱码,基本都是因为这里设置有问题造成的

如果你的文件是以GBK保存的,这里就改为GBK,如果是用utf-8,这里就改为utf-8就对了

read() 无参数:读取全部内容

    有参数:根据打开模式,如果有b,就按照字节读取,无b按照字符读取

  1. f = open('test', encoding='utf-8')
  2. data = f.read()
  3. print(data)
    f.close()

2、write

这个时候追加的信息会放到最后,那能不能调整写的位置呢?

  1. f = open('test', 'r+', encoding='utf-8')
  2. data = f.read()
  3. print(data)
  4. f.write('')
  5. f.close()
  6.  
  7. # 输出
  8. 1111
  9. 2222
  10. 3333
  11. 4444
  12. 5555
  13. 中文

3、seek: 调整指针位置(与打开模式没有关系,按照字节)

seek永远是以字节的方式去寻找位置,这个千万记住了

把888写到指针1的位置后边,并且覆盖了原来的111

  1. f = open('test', 'r+', encoding='utf-8')
  2. data = f.read()
  3. f.seek(1)
  4. print(data)
  5. f.write('')
  6. f.close()
  7.  
  8. # 输出
  9. 1888
  10. 2222
  11. 3333
  12. 4444
  13. 5555
  14. 中文

4、tell: 获取当前指针位置(与打开模式没有关系,按照字节)

test文件内容:

陈1888

  1. f = open('test', 'r+', encoding='utf-8')
  2. data = f.read(1)
  3. print('--->', f.tell())
  4. print(data)
  5. f.close()
  6.  
  7. # 输出
  8. ---> 3

5、readline: 一行一行读

  1. f = open('test', 'r+', encoding='utf-8')
  2. print(f.readline().strip())
  3. print(f.readline().strip())
  4.  
  5. f.close()

6、truncate: 截断数据

这个例子意思是:保留前5个字节内容,后边全部不要

  1. f = open('test', 'r+', encoding='utf-8')
  2. f.seek(5) # 把指针调整到第5个位置
  3. f.truncate()
  4. f.close()

7、readlines: 按行读取并返回列表

  1. f = open('test', 'r+', encoding='utf-8')
  2.  
  3. data = f.readlines()
  4. print(data)

8、最常用的使用循环一行一行读取文件

  1. f = open('test', 'r+', encoding='utf-8')
  2.  
  3. for line in f:
  4. print(line.strip())

9、flush:强制把内存的信息立刻写入的硬盘中

文件操作(with open)

1、with open 方式跟open的操作基本一样,是用with open 可以不用显性的是用f.close(),它自动进行关闭。

2、with open 方式支持同时打开2个以上的文件,这个open是不可以的。

  1. with open('test') as f1 , open('test1') as f2:
  2. data1 = f1.read()
  3. data2 = f2.read()
  4. print(data1)
  5. print(data2)

复制test文件前2行到test2文件

  1. with open('test') as f1, open('test2', 'x') as f2:
  2. count = 0
  3. for line in f1:
  4. if count < 2:
  5. f2.write(line)
  6. count += 1
  7. else:
  8. break

Python入门3的更多相关文章

  1. python入门简介

    Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC ...

  2. python入门学习课程推荐

    最近在学习自动化,学习过程中,越来越发现coding能力的重要性,不会coding,基本不能开展自动化测试(自动化工具只是辅助). 故:痛定思痛,先花2个星期将python基础知识学习后,再进入自动化 ...

  3. Python运算符,python入门到精通[五]

    运算符用于执行程序代码运算,会针对一个以上操作数项目来进行运算.例如:2+3,其操作数是2和3,而运算符则是“+”.在计算器语言中运算符大致可以分为5种类型:算术运算符.连接运算符.关系运算符.赋值运 ...

  4. Python基本语法[二],python入门到精通[四]

    在上一篇博客Python基本语法,python入门到精通[二]已经为大家简单介绍了一下python的基本语法,上一篇博客的基本语法只是一个预览版的,目的是让大家对python的基本语法有个大概的了解. ...

  5. Python基本语法,python入门到精通[二]

    在上一篇博客Windows搭建python开发环境,python入门到精通[一]我们已经在自己的windows电脑上搭建好了python的开发环境,这篇博客呢我就开始学习一下Python的基本语法.现 ...

  6. visual studio 2015 搭建python开发环境,python入门到精通[三]

    在上一篇博客Windows搭建python开发环境,python入门到精通[一]很多园友提到希望使用visual studio 2013/visual studio 2015 python做demo, ...

  7. python入门教程链接

    python安装 选择 2.7及以上版本 linux: 一般都自带 windows: https://www.python.org/downloads/windows/ mac os: https:/ ...

  8. Python学习【第二篇】Python入门

    Python入门 Hello World程序 在linux下创建一个叫hello.py,并输入 print("Hello World!") 然后执行命令:python hello. ...

  9. python入门练习题1

    常见python入门练习题 1.执行python脚本的两种方法 第一种:给python脚本一个可执行的权限,进入到当前存放python程序的目录,给一个x可执行权限,如:有一个homework.py文 ...

  10. Python入门版

    一.前言 陆陆续续学习Python已经近半年时间了,感觉到Python的强大之外,也深刻体会到Python的艺术.哲学.曾经的约定,到现在才兑现,其中不乏有很多懈怠,狼狈. Python入门关于Pyt ...

随机推荐

  1. Linux中的find(-atime、-ctime、-mtime)指令分析

    本篇主要对find -atime(-ctime..mtime)指令的用法.参数.运行情况进行分析 用法: find . {-atime/-ctime/-mtime/-amin/-cmin/-mmin} ...

  2. 画图程序升级版Draw_v1

    // https://github.com/orocos/orocos_kinematics_dynamics/blob/master/orocos_kdl/src/frames.hpp // Vec ...

  3. SpringMvc+Spring+Mybatis的jar包依赖关系图

  4. Java中长度为0的数组与null的区别

    有如下两个变量定义,这两种定义有什么区别呢? 1. int[] zero = new int[0]; 2. int[] nil = null; zero是一个长度为0的数组,我们称之为“空数组”,空数 ...

  5. web设计中那些因素可能影响网站后期优化

    web设计中那些因素可能影响网站后期优化. 1.网站代码的简洁实用性.网站源文件html代码.js代码.css代码等应尽可能的压缩处理.能用jquery-min.js的最好不要用jquery.js:c ...

  6. Intent中的四个重要属性——Action、Data、Category、Extras

    Intent作为联系各Activity之间的纽带,其作用并不仅仅只限于简单的数据传递.通过其自带的属性,其实可以方便的完成很多较为复杂的操作.例如直接调用拨号功能.直接自动调用合适的程序打开不同类型的 ...

  7. (进阶篇)PHP实现用户注册后邮箱验证,激活帐号

    我们在很多网站注册会员时,注册完成后,系统会自动向用户的邮箱发送一封邮件,这封邮件的内容就是一个URL链接,用户需要点击打开这个链接才能激活之前在该网站注册的帐号.激活成功后才能正常使用会员功能. 本 ...

  8. FTP应答码&响应码

    2016-06-16 00:57:25 110: 重新启动标记应答. 120: 在n分钟内准备好 125: 连接打开准备传送 150: 打开数据连接200: 命令成功202: 命令失败211: 系统状 ...

  9. JQuery EasyUI DataGrid常用操作及注意事项(未完)

    1.获取当前选中行,如果没有选中行,则返回 null var row = $('#gridID').datagrid('getSelected'); 2.获取当前所有选中行数据,返回的是选择的数组数据 ...

  10. ionic2配置问题集

    我在配置ionic2中遇到的问题,及我的解决方案. ionic start MyIonic2Project tutorial --v2 网络很坑爹,配置lantern后,也是多次尝试才下载成功. io ...