列表、元组、字典之前的互相转换

列表与元组的转换

# 列表转换成元组:使用 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—基础之杂货铺的更多相关文章

  1. Pyhton开发【第五篇】:Python基础之杂货铺

    Python开发[第五篇]:Python基础之杂货铺   字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进 ...

  2. Python开发【第五篇】:Python基础之杂货铺

    字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-310 ...

  3. 【Python之路】第五篇--Python基础之杂货铺

    字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存. 1.百分号方式 ...

  4. Python基础之杂货铺

    字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-310 ...

  5. 第四篇:python基础之杂货铺

    在这一篇中我们将对上几篇的Python零碎的知识进行补充,即字符串的格式化输出,以及深浅拷贝,接下来我们将对这两种进行一一介绍. 一.字符串格式化输出 关于字符串的格式化输出,我们需要了解为什么需要字 ...

  6. 第五章:Python基础の生成器、迭代器、序列化和虚拟环境的应用

    本课主题 生成器介紹和操作实战 迭代器介紹和操作实战 序例化和反序例化 Json 和 Pickle 操作实战 字符串格式化的应用 创建虚拟环境实战 本周作业 生成器介紹和操作实战 什么是生成器,生成器 ...

  7. python之最强王者(2)——python基础语法

    背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...

  8. Python开发【第二篇】:Python基础知识

    Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...

  9. Python小白的发展之路之Python基础(一)

    Python基础部分1: 1.Python简介 2.Python 2 or 3,两者的主要区别 3.Python解释器 4.安装Python 5.第一个Python程序 Hello World 6.P ...

随机推荐

  1. Tcp连接和断开

    三次握手:客户端为a,服务端为b:开始都是closed状态:a主动打开进入到syn_sent状态,b被动打开进入listen状态:第一次握手,a向b发送SYN=1,seq为x的包,b收到以后进入syn ...

  2. iotop使用方法

    iotop 是一个用来监视磁盘 I/O 使用状况的 top 类工具.iotop 具有与 top 相似的 UI,其中包括 PID.用户.I/O.进程等相关信息.   安装 yum install iot ...

  3. STL 中 string 的使用

    赋值 string 类型变量可以直接赋值 str = "string"; // str 是 一个 string 类型变量 //等价于 str.assign("string ...

  4. June 03rd, 2019. Week 23rd, Monday

    There is no shame in hard work. 努力从来不丢人. Stop complaining about the current work arrangements, just ...

  5. 2019面向对象程序设计(Java) 第16周学习指导及要求

    2019面向对象程序设计(Java)第16周学习指导及要求 (2019.12.13-2019.12.16) 学习目标 (1) 掌握Java应用程序的打包操作: (2) 掌握线程概念: (3) 掌握线程 ...

  6. npm简单实用

    npm包管理工具 npm可以理解为前端的maven,一个包的管理工具 1. 查看npm和node版本 node -v npm -v 2. 初始化项目 npm init 默认配置初始化项目 npm in ...

  7. SQL Server 约束的增删改

    1. 非空约束 列的为空性决定表中的行是否可以包含空值.空置(NULL)不同于零(0)/空白或者长度为零的字符串(“”). (1)创建非空约束 create table orders ( docent ...

  8. 第04组 Beta冲刺(4/5)

    队名:new game 组长博客 作业博客 组员情况 鲍子涵(队长) 过去两天完成了哪些任务 地图移动 接下来的计划 素材和脚本相连 引入声音素材 还剩下哪些任务 让游戏本体运行 遇到了哪些困难 时间 ...

  9. HTML连载42-清空默认边距、文字行高

    一.            webstorm取色技巧:webstorm内置了颜色取色器,我们对某种颜色未知的时候,可以利用下图中的取色器,进行颜色识别. 二.系统会默认给body添加外边距,因此我们对 ...

  10. Saiku默认给数据类型的数据添加小数点问题处理(三十一)

    Saiku默认给数据类型的数据添加小数点问题处理 不知道大家有没有遇到过saiku定义的维度信息,数据类型时 展示出来的数据会自动加上 .0的后缀. 比如我定义了一个维度为 年, 在数据库中为 int ...