2020-09-25 Python基础学习第三天笔记

这篇博客介绍了Python的基础知识,包括可变字符串的修改方法,如使用io.StringIO和array模块;详细阐述了二进制运算符的用法;深入讲解了列表的创建、常用命令,如append、extend、insert等,以及多维列表的操作;最后提到了元组的创建、排序、访问速度优势以及作为字典键的特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


2020-9-24 Day3

一、可变字符串

需要原地修改字符串,可以使用 ** io.StringIO 对象或 array ** 模块。

import io
>>> sio = io.StringIO(a)
>>> sio
<_io.StringIO object at 0x031C19B8>
>>> sio.getvalue()
'hello,sxt'
>>> sio.seek(7)
7
>>> sio.write('g')
1
>>> sio.getvalue()
'hello,sgt'

二、运算符

运算符优先顺序表
在这里插入图片描述

二进制运算
a|b | 对应位有一个是1,该位是1
a&b | 对应位都是1,该位是1
a^b | 对应位不同是1,相同是0

a<<2 #左移1位相当于乘2,左移2位相当于乘4
a>>1 #右移1位相当于除2,右移2位相当于除4

Python 不支持自加++,自减—

三、列表

1.列表的创建

两种方法:用[] 或者 list();
range([start],end[step])

>>> a = [x*2 for x in range(100) if x%9 == 0]
>>> a
[0, 18, 36, 54, 72, 90, 108, 126, 144, 162, 180, 198]
2.列表常用命令

在这里插入图片描述

  • 1.append() 原地修改列表对象,列表尾部添加新的元素,速度最快,推荐使用。对比:+是创建新的列表对象;将原列表的元素和新列表的元素依次复制到新的列表对象中。
  • 2.extend()将目标列表的所有元素添加到本列表的尾部,属于原地操作,不创建新的列表对象。
  • 3.insert(目标位置,值) 可以将指定的元素插入到列表对象的任意制定位置。插入位置后面所有的元素会进行移动,数据量大时,尽量避免使用。
  • 4.del list[位置] 删除列表指定位置的元素
  • 5.pop(位置) 删除并返回指定位置元素,如果未指定位置则默认操作列表最后一个元素。
  • 6.remove(值) 删除首次出现的指定元素,若不存在该元素抛出异常。
  • 7.index(value,[start,[end]]) 可以获取指定元素首次出现的索引位置, start 和end指定了搜索的范围:
    >>> a.index(30,5,7) #从索引位置5 到7这个区间,第一次出现 30元素的位置
  • 8.判断列表中是否存在指定的元素,一般我们会使用更加简洁的 in 关键字来判断,直接返回 True 或False。
>>> a = [10,20,30,40,50,20,30,20,30]
>>> 20 in a 
True
  • 9.ls.sort(reverse = False) 默认升序排列。 random.shuffle(ls)打乱顺序,记得import random. 也可以用sorted(ls,reverse = False)默认升序排列,这个方法返回新列表,不对原列表做修改。
  • 10.reversed()不对原列表做任何修改,只是返回一个逆序排列的迭代器对象。一次性的。
3.多维列表

a[m][n],m是行数-1,n是列数-1

a = [
["高小一",18,30000,"北京"], ["高小二",19,20000,"上海"], ["高小一",20,10000,"深圳"],
]

四、元组

列表属于可变序列,元组属于不可变序列。
-1.创建元组:两种方法,()或者tuple()

  • 2.元组只能用内置函数sorted()进行排序
  • 3.zip(列表1,列表2,…)可以将多个列表对应位置的元素组合成为元组,并返回这个zip对象。
>>> a = [10 ,20,30]
>>> b = [30,40,80]
>>> zip(a,b)
<zip object at 0x02F32548>
>>> list(zip(a,b))
[(10, 30), (20, 40), (30, 80)]
  • 4.元组的访问和处理速度比列表快。
  • 5.与整数和字符串一样,元组可以作为字典的键,列表则永远不能作为字典的键使用.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值