Python—基础之杂货铺
列表、元组、字典之前的互相转换
列表与元组的转换
# 列表转换成元组:使用 tuple 函数
num_list = [3, 6, 9]
num_tuple = tuple(num_list)
print num_tuple, type(num_tuple) # (3, 6, 9) <type 'tuple'> # 元组转换成列表:使用 list 函数
num_tuple = (2, 4, 6)
num_list = list(num_tuple)
print num_list, type(num_list) # [2, 4, 6] <type 'list'>
字符串格式化输出
字符串的格式化输出使得字符串的使用更加灵活、且格式输出一致。格式化输出的两种方式:百分号方式、format方式。
百分号方式
info = "My name is %s" % "杰伦"
print info # 结果:My name is 杰伦
info = "My name is %s, I'm %d years old" % ("杰伦", 22)
print info # 结果:My name is 杰伦, I'm 22 years old info = "My name is %(name)s, I'm %(age)d years old" % {"name":"杰伦", "age":22}
print info # 结果:My name is 杰伦, I'm 22 years old # 浮点数,并且指定小数点后的位数,四舍五入
st1 = "The number is %.2f" % 68.68888 # 结果:The number is 68.69
st2 = "The number is %6.2f" % 68.68888 # 结果:The number is 68.69
# 百分之几
st3 = "The number is %.2f%%" % 12.366566 # 结果:The number is 12.37%
st4 = "The number is %6.2f%%" % 12.366566 # 结果:The number is 12.37%
# 科学计数法
st5 = "The number is %e" % 11000012 # 结果:The number is 1.100001e+07
format方式
# 方式1:占位符为{},以元组的方式传入
info = "My name is {}, I'm {} years old".format("杰伦", 22)
# 方式2:占位符为{int},以元组的方式传入
info = "My name is {0}, I'm {1} years old".format("杰伦", 22)
info = "My name is {1}, I'm {0} years old".format(22, "杰伦")
info = "My name is {1}, I'm {0} years old".format(*[22, "杰伦"])
# 方式3:占位符为{key},以字典的方式传入
info = "My name is {name}, I'm {age} years old".format(name="杰伦", age=22)
info = "My name is {name}, I'm {age} years old".format(**{"name":"杰伦", "age":22})
# 传入列表中的元素
info1 = "My name is {0[0]},I'm {1[1]} years old.".format(["杰伦", "俊杰"], [22, 23])
# 规定传入的参数的格式,并且以元组的形式传入
info2 = "My name is {:s},I'm {:d} years old.".format("杰伦", 22)
# 规定传入的参数的格式,并且以字典的形式传入
info3 = "My name is {name:s},I'm {age:d} years old.".format(name="杰伦", age=22)
# 占位符->s:字符串,d:十进制,b:二进制,0:八进制,x:十六进制,X:大写十六进制,e:科学计数法,.2f:浮点数,保留两位小数
info4 = "numbers -->{:s},{:d},{:b},{:o},{:x},{:X},{:e},{:.2f}".format("hello",15,15,15,15,15,16.6666,16.3333)
# 如何将文本高亮显示
name ="\033[42;1m 杰伦 \033[0m"
print name
复制、深拷贝和浅拷贝的区别
复制
import copy ls1 = ["java", "python", [1,2,3]]
ls2 = ls1 ls2[0] = "c++"
print ls1, ls2 # 输出为:['c++', 'python', [1, 2, 3]] ['c++', 'python', [1, 2, 3]] ls2[2][0] = 6
print ls1, ls2 # 输出为:['c++', 'python', [6, 2, 3]] ['c++', 'python', [6, 2, 3]]
浅拷贝
import copy ls1 = ["java", "python", [1,2,3]]
ls2 = copy.copy(ls1) # 浅拷贝 # 修改列表中的不可变数据类型,ls2变,ls1不变
ls2[0] = "c++"
print ls1, ls2 # 输出为:['java', 'python', [1, 2, 3]] ['c++', 'python', [1, 2, 3]] # 修改列表中的可变数据类型时,ls2变,ls1也变
ls2[2][0] = 6
print ls1, ls2 # 输出为:['java', 'python', [6, 2, 3]] ['c++', 'python', [6, 2, 3]]
这是由于:浅拷贝-->拷贝的仅仅是原列表以及原列表元素中内存指针,故ls2中的不可变数据类型发生改变时,其内存指针也发生了改变,则当ls2[0]发生改变时,其内存指针发生改变,指向的不再存储"little-five"的内存空间,而是存放"xiaowu"的内存空间。故ls1不受影响。而当修改ls2中可变数据类型时,修改列表[1,2,3]中的元素时,该列表[1,2,3]的内存地址并不发生改变,故ls1和ls2的内存指针均指向该列表[1,2,3],故ls2发生该表,ls1也跟着改变。
修改ls2列表里的不可变数据类型(如字符串),则ls2[0]的地址值就发生了改变,与ls1[0]的地址值不是同一个了,则ls1列表的值也就不会发生改变。如果ls2增加一个元素,则ls1也不会改变。
修改ls2列表里的可变数据类型时(如列表),则ls2[2][0]的地址值没变,与ls1[2][0]的地址值还是同一个,只是这个地址值指向的值变了。
个人理解:列表里面存储的是地址。从下面例子可以看出可变数据类型和不可变数据类型的区别:
# 当修改不可变数据类型,其内存指针发生改变
name = "python"
print id(name) # 140357443045920
name = "java"
print id(name) # 140357443045968 # 当修改可变数据类型时,其内存指针不发生改变
arry = ["English", "Chinese", "Jpan"]
print id(arry) # 140357442918160
arry[2] = "USA"
print id(arry) # 140357442918160
深拷贝
import copy ls1 = ["java", "python", [1,2,3]]
ls3 = copy.deepcopy(ls1) # 深拷贝 ls3[0] = "c++"
print ls1, ls3 # 输出为:['java', 'python', [1, 2, 3]] ['c++', 'python', [1, 2, 3]] ls3[2][0] = 6
print ls1, ls3 # 输出为:['java', 'python', [1, 2, 3]] ['c++', 'python', [6, 2, 3]]
从上述例子可以看出,ls1与ls3再无任何关联,这是由于ls3拷贝过来时,其拷贝的不止内存指针,同时还创建新的内存空间,并将数据拷贝至新的内存空间。故新的内存指针指向新的内存空间。
Python—基础之杂货铺的更多相关文章
- Pyhton开发【第五篇】:Python基础之杂货铺
Python开发[第五篇]:Python基础之杂货铺 字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进 ...
- Python开发【第五篇】:Python基础之杂货铺
字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-310 ...
- 【Python之路】第五篇--Python基础之杂货铺
字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存. 1.百分号方式 ...
- Python基础之杂货铺
字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-310 ...
- 第四篇:python基础之杂货铺
在这一篇中我们将对上几篇的Python零碎的知识进行补充,即字符串的格式化输出,以及深浅拷贝,接下来我们将对这两种进行一一介绍. 一.字符串格式化输出 关于字符串的格式化输出,我们需要了解为什么需要字 ...
- 第五章:Python基础の生成器、迭代器、序列化和虚拟环境的应用
本课主题 生成器介紹和操作实战 迭代器介紹和操作实战 序例化和反序例化 Json 和 Pickle 操作实战 字符串格式化的应用 创建虚拟环境实战 本周作业 生成器介紹和操作实战 什么是生成器,生成器 ...
- python之最强王者(2)——python基础语法
背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...
- Python开发【第二篇】:Python基础知识
Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...
- Python小白的发展之路之Python基础(一)
Python基础部分1: 1.Python简介 2.Python 2 or 3,两者的主要区别 3.Python解释器 4.安装Python 5.第一个Python程序 Hello World 6.P ...
随机推荐
- Tcp连接和断开
三次握手:客户端为a,服务端为b:开始都是closed状态:a主动打开进入到syn_sent状态,b被动打开进入listen状态:第一次握手,a向b发送SYN=1,seq为x的包,b收到以后进入syn ...
- iotop使用方法
iotop 是一个用来监视磁盘 I/O 使用状况的 top 类工具.iotop 具有与 top 相似的 UI,其中包括 PID.用户.I/O.进程等相关信息. 安装 yum install iot ...
- STL 中 string 的使用
赋值 string 类型变量可以直接赋值 str = "string"; // str 是 一个 string 类型变量 //等价于 str.assign("string ...
- June 03rd, 2019. Week 23rd, Monday
There is no shame in hard work. 努力从来不丢人. Stop complaining about the current work arrangements, just ...
- 2019面向对象程序设计(Java) 第16周学习指导及要求
2019面向对象程序设计(Java)第16周学习指导及要求 (2019.12.13-2019.12.16) 学习目标 (1) 掌握Java应用程序的打包操作: (2) 掌握线程概念: (3) 掌握线程 ...
- npm简单实用
npm包管理工具 npm可以理解为前端的maven,一个包的管理工具 1. 查看npm和node版本 node -v npm -v 2. 初始化项目 npm init 默认配置初始化项目 npm in ...
- SQL Server 约束的增删改
1. 非空约束 列的为空性决定表中的行是否可以包含空值.空置(NULL)不同于零(0)/空白或者长度为零的字符串(“”). (1)创建非空约束 create table orders ( docent ...
- 第04组 Beta冲刺(4/5)
队名:new game 组长博客 作业博客 组员情况 鲍子涵(队长) 过去两天完成了哪些任务 地图移动 接下来的计划 素材和脚本相连 引入声音素材 还剩下哪些任务 让游戏本体运行 遇到了哪些困难 时间 ...
- HTML连载42-清空默认边距、文字行高
一. webstorm取色技巧:webstorm内置了颜色取色器,我们对某种颜色未知的时候,可以利用下图中的取色器,进行颜色识别. 二.系统会默认给body添加外边距,因此我们对 ...
- Saiku默认给数据类型的数据添加小数点问题处理(三十一)
Saiku默认给数据类型的数据添加小数点问题处理 不知道大家有没有遇到过saiku定义的维度信息,数据类型时 展示出来的数据会自动加上 .0的后缀. 比如我定义了一个维度为 年, 在数据库中为 int ...