python list 使用技巧

格式:list[start:stop:step]

示例:

a =list(range(0,10))

print(a[1:8:2]) #[1, 3, 5, 7]

print(a[:8:2])  #[0, 2, 4, 6]

print(a[:8])    #[0, 1, 2, 3, 4, 5, 6, 7]

print(a[:8:])  #[0, 1, 2, 3, 4, 5, 6, 7]

print(a[:8:1])  #[0, 1, 2, 3, 4, 5, 6, 7]

print(a[::-1])  #[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]  -----------使用-1 ,实现对列表或元素的反序

print(a[:3:-1])  #[9, 8, 7, 6, 5, 4]         ------------反序时,stop/start的值仍然是正序时的值,start > stop ,需要特别注意

print(a[8:1:-1]) #[8, 7, 6, 5, 4, 3, 2]

--------------------------------------------------------

示例:写一个程序,打印数字1到100,3的倍数打印“Fizz”来替换这个数,5的倍数打印“Buzz”,对于既是3的倍数又是5的倍数的数字打印“FizzBuzz”

for xin range(1,101):

print"fizz"[x%3*len('fizz')::]+"buzz"[x%5*len('buzz')::]or x

说明:

for x in range(1,10):

print(x,x % 3 * len('Fizz'),'---',"Fizz"[x % 3 * len('Fizz'):],"Fizz"[x % 3 * len('Fizz')::],'***',"Fizz"[x % 3 * len('Fizz')::] or x)

结果:

1 4 --- *** 1

2 8 --- *** 2

3 0 --- Fizz Fizz *** Fizz

4 4 --- *** 4

5 8 --- *** 5

6 0 --- Fizz Fizz *** Fizz

7 4 --- *** 7

8 8 --- *** 8

9 0 --- Fizz Fizz *** Fizz

  切片(索引运算符[]及start:stop)

       可以对序列类型(数组、列表、元组等)进行切片操作,start索引处元素被包括在切片的结果中,stop索引处的元素未被包括在结果中,元素数量为 stop-start。start或stop都是可以省略的,此时他们分别默认为序列的起始处和结尾处。

        还可以在第二个冒号后加上步长(step),比如每隔一位取一个元素。

   可以巧妙的使用 -1 ,实现对列表或元素的反序

以下为转载,源自:https://blog.csdn.net/shaxiaozilove/article/details/79685168

1、合并列表(extend)

       跟元组一样,用加号(+)将两个列表加起来即可实现合并:

 

对于已定义的列表,可以用extend方法一次性添加多个元素:

 

需要说明的是:加号(+)执行列表的合并是非常浪费资源的,因为必须创建一个新列表并将所有对象复制过去,而用extend将元素附加到现有列表(尤其是在构建一个大列表时)就会好很多。

 因此,在进行列表合并操作时,尤其是对于大数据量的列表合并,强烈建议使用extend函数。

 

2、列表排序(sort)

       列表的sort方法可以实现就地排序(无需创建新对象,字符串按首字母进行排序)

 

sort有几个很好用的选项,一个是次要排序键,即一个能够产生可用于排序的值的函数。如可以通过长度对一组字符串进行排序:

 

再比如是否进行降序排列,如下面通过对首字母进行降序排列的示例:

 

3、 二分搜索及维护有序列表(bisect)

       内置的bisect模块实现了二分查找以及对有序列表的插入操作。bisect.bisect可以找出新元素应该被插入到哪个位置以保持元列表的有序性,bisect.insort则将新元素插入到那个正确的位置上。

 

 注意:bisect模块的函数不会判断原列表是否有序,因为这样做开销太大;因此将他们用作无序列表时虽然不会出错,但可能会导致不正确的结果。基于此,建议在使用bisect模块的函数前,先对原列表执行排序的操作。

3、切片(索引运算符[]及start:stop)

       可以对序列类型(数组、列表、元组等)进行切片操作,start索引处元素被包括在切片的结果中,stop索引处的元素未被包括在结果中,元素数量为 stop-start。start或stop都是可以省略的,此时他们分别默认为序列的起始处和结尾处。

        还可以在第二个冒号后加上步长(step),比如每隔一位取一个元素:

 

可以巧妙的使用 -1 ,实现对列表或元素的反序,如下:

 

4、列表内置的序列函数

       4.1 enumerate

       enumerate函数可以逐个返回序列的(i, value)元组,如下示例:

 

4.2 sorted

       sorted函数可以将任何序列返回为一个新的有序列表(注意:sort函数是就地排序),如下:

 

常常将sorted和set结合起来使用以得到一个由序列中的唯一元素构成的有序列表:

 

 上面的结果都是一样的,什么原因呢?这是因为:(1)set和sorted是对序列进行操作,当参数不是序列时,会默认转换为列表;(2)set默认会对元素进行排序。

 

 4.3 zip

       zip用于将多个序列(列表、元组等)中的元素“配对”,从而产生一个新的元组列表;zip可以接受任意数量的序列,最终得到的元组数量由最短的序列决定;zip最常见的用法是同时迭代多个序列,还可以结合enumerate一起使用,如下:

 

对于“已压缩的”(zipped)序列,zip还有一个很巧妙的用法,即对该序列进行解压(unzip,用*表示)。其实就是将一组行转换为一组列,如下:

 

4.4 reversed

    用于按逆序迭代序列中的元素,如下:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值