一,字符串和列表的转换

1.str中的 join 方法: 把列表转换成字符串

# 将列表转换成字符串. 每个元素之间用_连接

s = '**'.join(['李启政',' 郑强' , '孙福来']) print(s)  #s = ["李启政"**"郑强"**"孙福来"]

ss = "李启政**郑强**孙福来" ss.split("**") print(ss)

字符串转化成列表: split()

把列表转化成字符串: join()

s = "_",join('马化腾')
print(s)
# s = ('马_化_藤')

join (可迭代对象)

2.列表和字典在循环的过程中不能直接删除,与要把要删除的内容记录在新列表中,然后循环新列表,删除字典或者列表.


lst = ["紫云", "大云", "玉溪", "紫钻","a","b"]
lst.clear() new_lst = [] # 准备要删除的信息
for el in lst: # 有一个变量来记录当前循环的位置
new_lst.append(el) # 循环新列表, 删除老列表
for el in new_lst:
lst.remove(el)
#
# # 删除的时候, 发现. 剩余了一些内容. 原因是内部的索引在改变.
# # 需要把要删除的内容记录下来. 然后循环这个记录. 删除原来的列表
#
# print(lst)
# print(new_lst)
 

**   列表  清空及删除

例 : lst = ["张国荣", '张铁林', '张国立', "张曼玉", "汪峰"]

(1)删除姓张的

zhangs = []
for el in lst:
if el.startswith("张"):
zhangs.append(el)
for el in zhangs:
lst.remove(el)
print(lst)

(2)记录姓张的

zhangs = []
for el in lst:
if el.startswith("张"):
zhangs.append(el)
for el in zhangs:
lst.remove(el)
print(zhangs)

** 字典   清空及删除

例 : dic = {"提莫":"冯提莫", "发姐":"陈一发儿", "55开":"卢本伟"}

dic = {"提莫":"冯提莫", "发姐":"陈一发儿", "55开":"卢本伟"}
lst = []
for k in dic:
lst.append(k)
for el in lst:
dic.pop(el)
print(dic)

综上,列表和字典都不能在循环的时候进行删除,字典在循环的时候不能改变大小长度.

3.fromkeys()

(1)返回新字典,对原字典没有影响

(2)后面的value,是多个key共享的一个value.

例:  dic = {"apple":"苹果", "banana":"香蕉"}

dic = {"apple":"苹果", "banana":"香蕉"}
# 返回新字典. 和原来的没关系
ret = dic.fromkeys("orange", "橘子") # 直接用字典去访问fromkeys不会对字典产生影响
ret = dict.fromkeys("abc",["哈哈","呵呵", "吼吼"]) # fromkeys直接使用类名进行访问
print(ret)
a = ["哈哈","呵呵", "吼吼"]
ret = dict.fromkeys("abc", a) # fromkeys直接使用类名进行访问
a.append("嘻嘻")
print(ret)

二.set集合

特点: 无序,不重复,元素必须可哈希(不可变).

作用:  去重复

本身是可变类型,有增删改查操作.

frozenset()冻结的集合, 不可改变,可哈希的.

set  去重复

例: s = {"周杰伦", "的老婆","叫昆凌", (1,2,3), "周杰伦"}

s = {"周杰伦", "的老婆","叫昆凌", (1,2,3), "周杰伦"}
s = set(s)
print(s) # s = {"周杰伦", "的老婆","叫昆凌", (1,2,3)}

set  把列表转换成集合. 进行去重复 ,再把集合转换回列表.

例: lst = [11,5,4,1,2,5,4,1,25,2,1,4,5,5]

lst = [11,5,4,1,2,5,4,1,25,2,1,4,5,5] s = set(lst) # 把列表转换成集合. 进行去重复 lst = list(s) # 把集合转换回列表. print(lst)   #lst = [1,2,4,5,11,25]

集合本身是可变的数据类型, 不可哈希, 有增删改查操作,

例:  s = {"刘嘉玲", '关之琳', "王祖贤"}

s = {"刘嘉玲", '关之琳', "王祖贤"}
s.update("麻花藤") # 迭代更新
print(s) #{'麻', '藤', '刘嘉玲', '关之琳', '花', '王祖贤'}

集合中的元素必须是可哈希的 .不重复的. 可以去重.

集合的增删改查

1,增: add  : 重复的内容不会被添加到set集合中 和     update : 迭代更新

s = {"刘嘉玲", '关之琳', "王祖贤"}
s.add("郑裕玲")
print(s) s.add("郑裕玲") # 重复的内容不会被添加到set集合中
print(s)
s = {"刘嘉玲", '关之琳', "王祖贤"}
s.update("麻花藤") # 迭代更新
print(s) s.update(["张曼玉", "李若彤","李若彤"])
print(s)

2.删: pop() : 随机删除(随机弹出一个)   remove() :直接删除元素      clear():清空set集合.需要注意的是set集合如果是空的. 打印出来是set() 因为要和 dict区分的.

s = {"刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}
item = s.pop() # 随机弹出一个.
print(s)
print(item)
s.remove("关之琳") # 直接删除元素
# s.remove("马虎疼") # 不存在这个元素. 删除会报错
print(s)
s.clear() # 清空set集合.需要注意的是set集合如果是空的. 打印出来是set() 因为要和
dict区分的.
print(s) # set()

3.改:set集合中的数据没有索引. 也没有办法去定位一个元素. 所以没有办法进⾏直接修改. 我们可以采取先删除后添加的方式来完成修改操作

s = {"刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}
# 把刘嘉玲改成赵本山
s.remove("刘嘉玲")
s.add("赵本山")
print(s)

4.查: set是一个可迭代对象. 所以可以进行for循环

for el in s: print(el)

三.深浅拷贝(难点)

1. 赋值,没有创建新对象,共用一个对象

2.浅拷贝,拷贝第一层内容, [ : ]或 copy( )

3.深拷贝,拷贝所有内容,包括内部的所有.

例: lst1 = ["金毛狮王", "紫衫龙王", "青翼蝠王", "白眉鹰王",["张无忌","赵敏","周芷若"]]

浅拷贝

lst1 = ["金毛狮王", "紫衫龙王", "青翼蝠王", "白眉鹰王",["张无忌","赵敏","周芷若"]]
lst2 = lst1[:] # 浅拷贝
lst2 = lst1.copy() # 浅拷贝 lst1[4].append("小昭") print(lst1)
print(lst2) print(id(lst1[4]))
print(id(lst2[4]))

#['金毛狮王', '紫衫龙王', '青翼蝠王', '白眉鹰王', ['张无忌', '赵敏', '周芷若', '小昭']]
     ['金毛狮王', '紫衫龙王', '青翼蝠王', '白眉鹰王', ['张无忌', '赵敏', '周芷若', '小昭']]
地址一样  40206664
         40206664

深拷贝

lst1 = ["金毛狮王", "紫衫龙王", "青翼蝠王", "白眉鹰王",["张无忌","赵敏","周芷若"]]

lst1[4].append("小昭")
lst2 = copy.deepcopy(lst1)  # 深拷贝
print(lst1) print(lst2) print(id(lst1[4])) print(id(lst2[4]))

#['金毛狮王', '紫衫龙王', '青翼蝠王', '白眉鹰王', ['张无忌', '赵敏', '周芷若', '小昭']]
      ['金毛狮王', '紫衫龙王', '青翼蝠王', '白眉鹰王', ['张无忌', '赵敏', '周芷若', '小昭']]
地址不同  42238280
         42239688

python随笔 join 字典,列表的清空 set集合 以及深浅拷贝(重点..难点)的更多相关文章

  1. python 补充:join() , 基本数据类型的增删改查以及深浅拷贝

    #  join() join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串. li = ["李李嘉诚", "麻花藤", "黄海海峰&q ...

  2. Python 入门之代码块、小数据池 与 深浅拷贝

    Python 入门之代码块.小数据池 与 深浅拷贝 1.代码块 (1)一个py文件,一个函数,一个模块,终端中的每一行都是代码块 (代码块是防止我们频繁的开空间降低效率设计的,当我们定一个变量需要开辟 ...

  3. python中 字符 字典 列表之间的转换

    1 字典 转 字符 定义一个字典:dict = {'name': 'python', 'age': 7}字典转字符 可以使用str强制转换 如: str(dict) 此时dict的类型就是字符型了 2 ...

  4. python的推导式 —— 列表推导式、集合和字典推导式

    python的推导式是用于快速处理数据的方法. 主要有:列表推导式.集合推导式和字典推导式 import time import numpy as np 列表推导式: 1. 速度快 t1 = time ...

  5. python之set集合、深浅拷贝

    一.基本数据类型补充 1,关于int和str在之前的学习中已经介绍了80%以上了,现在再补充一个字符串的基本操作: li = ['李嘉诚','何炅','海峰','刘嘉玲'] s = "_&q ...

  6. str中的join方法,fromkeys(),set集合,深浅拷贝(重点)

    一丶对之前的知识点进行补充 1.str中的join方法.把列表转换成字符串 # 将列表转换成字符串,每个元素之间用_拼接 s = "_".join(["天",& ...

  7. python之set集合及深浅拷贝

    一.知识点补充 1.1字符串的基本操作 li =["李李嘉诚", "麻花藤", "⻩黄海海峰", "刘嘉玲"] s = ...

  8. 从入门到自闭之Python集合,深浅拷贝(大坑)

    小数据池 int: -5~256 str: 字母,数字长度任意符合驻留机制 字符串进行乘法时总长度不能超过20 特殊符号进行乘法时只能乘以0 代码块: 一个py文件,一个函数,一个模块,终端中的每一行 ...

  9. python day 07-数据类型补充,集合,深浅拷贝

    一.基础数据类型补充 1.列表转字符串 a='A'.join(['c','c','s']) print(a) 2.循环删除列表中的每⼀一个元素 lst=['asdf','dftgst','zsdrfs ...

随机推荐

  1. Mybatis九( mybatis插件的原理及使用)

    1.插件执行原理 一.demo 1.测试类 @Test public void test1() { String resource = "mybatis-config.xml"; ...

  2. asp.net(C#)文件操作

    //创建文件夹路径 string path = "\\Files\\"; //判断文件夹是否存在 if (!Directory.Exists(path)) {     Direct ...

  3. Linux 文件查找(find)

    find(选项)(参数) 选项 -amin<分钟>:查找在指定时间曾被存取过的文件或目录,单位以分钟计算: -anewer<参考文件或目录>:查找其存取时间较指定文件或目录的存 ...

  4. centos-yum离线源

    配置离线源 在个别开发环境中,我们可能有限制不能连外网. 这个情况可以通过用一台同内网的机器配置离线源,然后通过vsftp公用. 安装ftp rpm命令详解 $ rpm -ivh apache-1.3 ...

  5. 前后台交互实现点击超链接通过指定的 url 去网络或者文件服务器下载文件

    前台 VUE 界面: <el-table-column prop="attachment" align="center" label="附件详情 ...

  6. php中显示数组与对象的实现代码

    1. 使用 print_r ( $array/$var ) print 是打印的意思,而r则取自Array的单词,那么该函数的功能就是打印数组内容,它既可以打印数组内容,也可以打印普通的变量. pri ...

  7. intellij idea远程debug调试resin4教程

    昨天有个项目部署在阿里云 想远程调试不知道怎么弄.看日志需要账户密码很不方便呀.今天加班特意baidu了下. 1.先在远程的resin修改conf中resin.xml配置文件 在server-defa ...

  8. C++复习:C++的类型转换

    C++的类型转换 1 类型转换名称和语法 C风格的强制类型转换(Type Cast)很简单,不管什么类型的转换统统是: TYPE b = (TYPE)a C++风格的类型转换提供了4种类型转换操作符来 ...

  9. sql中优化查询

    1.在大部分情况下,where条件语句中包含or.not,SQL将不使用索引:可以用in代替or,用比较运算符!=代替not. 2.在没有必要显示不重复运行时,不使用distinct关键字,避免增加处 ...

  10. Linux命令:findutils

    本篇介绍Linux中常用的文件查找和定位工具,包括:find.locate.which.xargs等. GNU find 命令参考<https://www.gnu.org/software/fi ...