一:关于str 的操作方法补充

1,s.isspace()   判断字符串是否只由空格组成,是,为True,否则,为False。

s = ' ' #只能是以至少一个空格组成的字符串(全空格)
print(s.isspace())

二:关于tuple类型的补充

当元组只有一个元素组成并且没有逗号,则该元素是什么数据类型,整体就是什么数据类型。

tu = ('alex')
tu1 = ('alex',)
print(tu,type(tu))
print(tu1,type(tu1)) tu = ([1,2,3])
tu1 = ([1,2,3],)
print(tu,type(tu))
print(tu1,type(tu1))
tu.append('')
print(tu)

三:关于list的方法补充

在循环一个列表时,如果要是删除某些或者某类元素,容易出错,因为在依靠索引删除元素时,列表的的长度会发生变化,最终会导致索引超出列表长度范围。如将列表 l1 = [111,222,333,444,555] 将索引为基数位的元素删除。有以下三种方法,程序如下。

# 方法一:
l1 = [111,222,333,444,555]
l2 = []
for i in range(len(l1)):
if i % 2 == 0:
l2.append(l1[i])
l1 = l2
print(l1) #方法二:
l1 = [111,222,333,444,555,666,777]
del l1[1::2]
print(l1) #方法三
l1 = [111,222,333,444,555]
for i in range(len(l1)-1,0,-1):
if i % 2 == 1:
del l1[i]
print(l1)

四:关于dict的方法补充

1,关与dict.fromkeys()的用法

dic = dict.fromkeys('abc','alex')
print(dic) #{'a': 'alex', 'b': 'alex', 'c': 'alex'} dic1 = dict.fromkeys([1,2,3],[])
print(dic1) #{1: [], 2: [], 3: []}
dic1[1].append('alex')
print(dic1) #{1: ['alex'], 2: ['alex'], 3: ['alex']}

2, 在循环一个字典时,如果删除某些键值对,可能会报错。如要删除字典dic = {"k1":"alex","k2":"ritian","k3":"wusir",k4:"taibai"},要删除当前字典中带k的键值对时,有以下方法,程序如下:

dic = {'k1':'alex','k2':'太白','k3':'日天','name':'wusir'}
l1 = []
for i in dic:
if 'k' in i:
l1.append(i)
print(l1)
for k in l1:
del dic[k]
print(dic)

五:数据类型之间的转换

1,利用split可以把str类型转换为list类型,通过join也可以把list转化为str

2,dict转化为list类型时,方法如下:

dic = {'k1':'alex','k2':'太白','k3':'日天','name':'wusir'}
print(list(dic.keys())) #['k1', 'k2', 'k3', 'name']
print(list(dic.values())) #['alex', '太白', '日天', 'wusir']
print(list(dic.items())) #[('k1', 'alex'), ('k2', '太白'), ('k3', '日天'), ('name', 'wusir')]

六:深浅copy

1,关于赋值运算,有如下程序:

l1 = [1,2,3,4]
l2 = l1
l1.append(5)
print(l1,l2)

最后打印的l1, l2结果相同,都是[1,2,3,4,5], 因为对于对于赋值运算,指向的都是同一个内存地址,因此当其中一个改变时,另一个也会随之改变。

2,浅copy

对于浅copy来说,第一层都是独立的内存地址,从第二层开始,都是指向同一个内存地址,一变都变。如下代码:

l1 = [1,2,3]
l2 = l1.copy()
l1.append(666)
print(l1,id(l1)) #[1, 2, 3, 666] 2845193877768
print(l2,id(l2)) #[1, 2, 3] 2845193877128 l1 = [1,[22,33,],2,3]
l2 = l1.copy()
l1[1].append(666)
print(l1,id(l1),id(l1[1])) #[1, [22, 33, 666], 2, 3] 2409427777160 2409427777800
print(l2,id(l2),id(l2[1])) #[1, [22, 33, 666], 2, 3] 2409456421384 2409427777800

3,深copy
    对于深copy,无论多少层,在内存中都是两个独立的内存地址。如下代码:

import copy
l1 = [1,[22,33,],2,3]
l2 = copy.deepcopy(l1)
l1.append(777)
l1[1].append(666)
print(l1,id(l1),id(l1[1])) #[1, [22, 33, 666], 2, 3, 777] 2015999390280 2015999391624
print(l2,id(l2),id(l2[1])) #[1, [22, 33], 2, 3] 2015999506440 2015999506504

ps:若对一个列表从头到尾进行切片,则它是浅copy还是深copy呢?例如下的程序:

l1 = [1,[1,2],2,3]
l2 = l1[:]
l1[1].append(111)
print(l1,l2) #l1=l2=[1, [1, 2, 111], 2, 3]

最后,得到的结果是 l1=l2=[1,[1,2,111]  ,2 ,3], 可见,该列表的内层发生改变时,则对其切片的列表也随之发生了改变,所以,l1和l2的内层都指向同一个内存地址,故这是一个浅copy。

基础数据类型的补充和深浅copy的更多相关文章

  1. python之路--基础数据类型的补充与深浅copy

    一 . join的用法 lst =['吴彦祖','谢霆锋','刘德华'] s = '_'.join(lst) print(s) # 吴彦祖_谢霆锋_刘德华 # join() "*" ...

  2. 基础数据类型之集合和深浅copy,还有一些数据类型补充

    集合 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. 关系 ...

  3. Python基础学习Day7 基础数据类型的扩展 集合 深浅copy

    一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...

  4. python--基础数据类型的补充与深浅copy

    一 . join的用法 lst =['吴彦祖','谢霆锋','刘德华'] s = '_'.join(lst) print(s) # 吴彦祖_谢霆锋_刘德华 # join() "*" ...

  5. 07、python的基础-->数据类型、集合、深浅copy

    一.数据类型 1.列表 lis = [11, 22, 33, 44, 55] for i in range(len(lis)): print(i) # i = 0 i = 1 i = 2 del li ...

  6. 《Python》 基础数据类型补充和深浅copy

    一.基础数据类型的补充 元组: 如果元组中只有一个数据,且没有逗号,则该‘元组’数据类型与里面的数据类型一致 列表: 列表之间可加不可减,可跟数字相乘 l1=['wang','rui'] l2=['c ...

  7. 基础数据类型汇总补充;集合set ;深浅copy

    首先回顾: 小数据池:int -5~256str 特殊字符,*数字20 ascii : 8位 1字节 表示1个字符unicode 32位 4个字节 表示一个字符utf- 8 1个英文 8位,1个字节 ...

  8. 基础数据类型汇总补充,python集合与深浅拷贝

    一.基础数据类型汇总补充 1.查看str所有方法方式 2.列表:在循环中删除元素,易出错或报错(飘红) lis = [11,22,33,44,55] # for i in range(len(lis) ...

  9. 百万年薪python之路 -- 基础数据类型的补充

    基础数据类型的补充 str: 首字母大写 name = 'alexdasx' new_name = name.capitalize() print(new_name) 通过元素查找下标 从左到右 只查 ...

随机推荐

  1. html5 storage事件

    HTML5 虽然很多年了,但是真的了解不不够不够.主题说的是 storage时间,说起对 storage 事件的了解还是从 QQ音乐 说起. QQ音乐的主页是 https://y.qq.com , 而 ...

  2. C#Winform使用mysql作为本地数据库

    MYSQL是老牌关系型数据库,在受够了sqlite,mslocaldb,sqlce等本地数据库之后,发现了mysql5.6的一些版本也可以绿色安装,编程实现从资源文件里面解压到目标机器上,并配置好成为 ...

  3. Java框架之Hibernate(四)

    本文主要介绍: 1 悲观锁和乐观锁 2 使用版本号控制并发访问 3 flush方法和批量更新的问题 4 DetachedCriteria 5 N + 1 次查询 6 使用sql进行查询 7 注解方式 ...

  4. BitCoin p2p通信过程

    众所周知,Bitcoin是建立在p2p网络上的,但是具体的通信过程一直没有搞懂,所以特意去bitcoin的Developer Guid上去了解了一下.由于本人英文水平有限,理解难免有偏差的地方,希望大 ...

  5. ReSharper 全教程

    Resharper系列 更多关于Resharper的介绍 参考我之前的文章: Resharper 详细教程 提升ReSharper和Visual Studio的性能 Visual Studio中使用R ...

  6. Android App版本自动更新

    App在开发过程中,随着业务场景的不断增多,功能的不断完善,早期下载App的用户便无法体验最新的功能,为了能让用户更及时的体验App最新版本,在App开发过程加入App自动更新功能便显得尤为重要.更新 ...

  7. Android基础_BroadcastReceiver

    一:什么是BroadcastReceiver Broadcast(广播)是一种广泛运用于在应用程序之间一步传播消息的机制系统消息Android系统发出的,电池不足.来电信息等自定义消息第三方应用发出的 ...

  8. 【LCT维护基环内向树森林】BZOJ4764 弹飞大爷

    4764: 弹飞大爷 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 101  Solved: 52[Submit][Status][Discuss] ...

  9. 【原】IOS兼容性之APP内fixed定位头部跳动

    兼容现象: 在App的webview里边,我们有时候会在页面里写自定义头部,会使用到fixed定位,我们想要的效果是,页面无论怎么滑动,这个自定义的头部始终是固定在顶部的,但是在ios 11以上的版本 ...

  10. InnoDB一棵B+树可以存放多少行数据?

    一个问题? InnoDB一棵B+树可以存放多少行数据?这个问题的简单回答是:约2千万.为什么是这么多呢?因为这是可以算出来的,要搞清楚这个问题,我们先从InnoDB索引数据结构.数据组织方式说起. 我 ...