python列表操作函数 Python列表操作

Python中列表的方法有什么?

Python中的列表内建了许多方法。在下文中,使用“L”代表一个列表,使用“x”代表方法的参数,以便说明列表的使用方法。

成都创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站建设、网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的延庆网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

1 append()方法

列表的append()方法用于将一个项添加到列表的末尾,L.append(x)等价于L[len(L):] = [x]。

例如,使用append()方法分别将'cow'和'elephant'添加到animals列表的末尾:

animals = ['cat', 'dog', 'fish', 'dog']

animals.append('cow')   # 等价于animals[4:]=['cow']

animals

['cat', 'dog', 'fish', 'dog', 'cow']

animals.append('elephant')   # 等价于animals[5:]=['elephant']

animals

['cat', 'dog', 'fish', 'dog', 'cow', 'elephant']

2 ()方法

列表的()方法用于将一个项插入指定索引的前一个位置。L.(0, x)是将x插入列表的最前面,L.(len(L)), x)等价于L.append(x)。

例如,使用()方法分别将'cow'和'elephant'插入animals列表:

animals =  ['cat', 'dog', 'fish', 'dog']

animals.(0, 'cow')

animals

['cow', 'cat', 'dog', 'fish', 'dog']

animals.(3, 'elephant')

animals

['cow', 'cat', 'dog', 'elephant', 'fish', 'dog']

3 extend()方法

列表的extend()方法用于将可迭代对象的所有项追加到列表中。L.extend(iterable)等价于L[len(L):] = iterable。extend()和append()方法的区别是,extend()方法会将可迭代对象“展开”。

例如,分别使用append()方法和extend()方法在animals列表后面追加一个包含'cow'和'elephant'的列表:

animals = ['cat', 'dog', 'fish', 'dog']

animals.append(['cow', 'elephant'])   # 此处append()参数是一个列表

animals

['cat', 'dog', 'fish', 'dog', ['cow', 'elephant']]

animals = ['cat', 'dog', 'fish', 'dog']

animals.extend(['cow', 'elephant'])   # 此处extend()参数也是一个列表

animals

['cat', 'dog', 'fish', 'dog', 'cow', 'elephant']

4 remove()方法

列表的remove()方法用于移除列表中指定值的项。L.remove(x)移除列表中第一个值为x的项。如果没有值为x的项,那么会抛出ValueError异常。

例如,使用remove()方法移除animals列表中值为'dog'的项:

animals = ['cat', 'dog', 'fish', 'dog']

animals.remove('dog')

animals

['cat', 'fish', 'dog']

animals.remove('dog')

animals

['cat', 'fish']

animals.remove('dog')

Traceback (most recent call last):

File "", line 1, in

ValueError: list.remove(x): x not in list

5 pop()方法

列表的pop()方法用于移除列表中指定位置的项,并返回它。如果没有指定位置,那么L.pop()移除并返回列表的最后一项。

例如,使用pop()方法移除animals列表中指定位置的项:

animals = ['cat', 'dog', 'fish', 'dog']

animals.pop()

'dog'

animals

['cat', 'dog', 'fish']

animals.pop(2)

'fish'

animals

['cat', 'dog']

在调用前面的列表方法后,并没有打印任何值,而pop()方法打印了“弹出”的值。包括append()、()、pop()在内的方法都是“原地操作”。原地操作(又称为就地操作)的方法只是修改了列表本身,并不返回修改后的列表。

在类型转换时使用的int()函数,str()函数都有返回值:

number = 123

mystring = str(number)   # 将返回值赋给变量mystring

mystring

'123'

但是在使用“原地操作”时,大部分则不会有返回值,包括pop()方法也只是返回了被“弹出”的值,并没有返回修改后的列表:

animals = ['cat', 'dog', 'fish', 'dog']

new_animals = animals.append('cow')

print(new_animals)

None

关于Python的基础问题可以看下这个网页的视频教程,网页链接,希望我的回答能帮到你。

python list(range(1,10,3))结果是什么?

Python语句list(range(1,10,3))执行结果为[1,4,7]。

语法是:range(start,stop[,step])

参数说明:

(1)start:计数从start开始,默认是从0开始。例如range(5)等价于range(0,5);

(2)stop:计数到stop结束,但不包括stop。例如:range(0,5)是[0,1,2,3,4]没有5;

(3)step:步长,默认为1。例如:range(0,5)等价于range(0,5,1)。

因此,range(1,10,3)的意思是1到10之间的tuple,间隔为3,所以结果是(1,4,7)。

列表(List)是最常用的Python数据类型,它可以作为一个方括号内的逗号分隔值出现。

所以,list(range(1,10,3))执行结果为[1,4,7]。

扩展资料

Python列表函数方法

Python包含以下函数:

1、cmp(list1, list2):比较两个列表的元素;

2、len(list):列表元素个数;

3、max(list):返回列表元素最大值;

4、min(list):返回列表元素最小值;

5、list(seq):将元组转换为列表。

Python包含以下方法:

1、list.append(obj):在列表末尾添加新的对象;

2、list.count(obj):统计某个元素在列表中出现的次数;

3、list.extend(seq):在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表);

4、list.index(obj):从列表中找出某个值第一个匹配项的索引位置;

5、list.insert(index, obj):将对象插入列表;

6、list.pop([index=-1]):移除列表中的一个元素(默认最后一个元素),并且返回该元素的值;

7、list.remove(obj):移除列表中某个值的第一个匹配项;

8、list.reverse():反向列表中元素;

9、list.sort(cmp=None, key=None, reverse=False):对原列表进行排序。

Python对列表排序函数sort()和reverse()的讲解

列表中的数据种类很多,有字符串,有整型,有其他列表的嵌套,还有更多的数据类型,这些数据在列表中往往是错乱的,没有一定的逻辑关系,但是我们在使用列表的时候往往需要按照一定的逻辑关系进行调用或检索。下面就来看看 列表是如何排序和翻转的 ,所谓翻转也就是把既定列表倒序排列。

返回结果:

从上面的返回结果可以看出来,sort()函数如果遇到字符串是按照首字母顺序进行排列的,如果遇到浮点型数据还是按照大小排列。

由上面的结果可以看出来,不同的数据类型是没有办法进行排列的。

这个方法是把原列表中的元素顺序从左至右的重新存放,而不会对列表中的参数进行排序整理。如果需要对列表中的参数进行整理,就需要用到列表的另一种排序方式sort正序排序。

python中list(range())、range()、list()函数的用法

转自

Python  range() 函数返回的是一个可迭代对象(类型是对象),而不是列表类型, 所以打印的时候不会打印列表。

函数语法:

range(stop)range(start,stop,step)//默认start为0,step为1

Python  list() 函数是对象迭代器,可以把range()返回的可迭代对象转为一个列表,返回的变量类型为列表。

list() 方法用于将元组转换为列表。

注: 元组与列表是非常类似的,区别在于元组的元素值不能修改,元组是放在括号中( ),列表是放于方括号中[ ]。

元组中只包含一个元素时,需要在元素后面添加逗号

tup1=(50,)

list、元组与字符串的索引一样,列表索引从0开始。列表可以进行截取、组合等。

四、 python中的数据类型——列表

列表是一种有序的集合,有点类似c里面的数组。它的特点是,可以随时向里面添加或删除其中的元素,在python中经常用来存放数据。列表的特点是中括号,内部元素用逗号隔开。

在这个列表中,可以放进去任何元素,不论你的元素是字符串、整型、浮点型、还是布尔值、空值,包括列表什么的,都可以放进去。

元素与元素之间,用逗号隔开。

列表会为每个元素分配序号,这个序号代表它的位置,称为索引(index),第一个元素的位置是0,第二个元素是1,以此类推。

使用索引获取列表中的值时,需要使用中括号来访问,在中括号前面加上列表名,中括号内部是元素的索引。

0代表第一个元素的位置,1代表第二个,-1代表倒数第一个,-2代表倒数第二个

使用 len() 函数,可以查看列表里面有多少个元素

在python中,列表的操作是非常的灵活的,我们可以向其中添加或删除元素。

添加使用 list.append() 函数

list.append() 函数是将元素插入到列表的末尾,当我们想在特定位置插入元素时可以使用 list.insert() 函数

list.insert() 函数接受两个参数,第一个参数是插入位置,第二个参数是要插入的元素。

需要注意的是,在使用append和insert时,必须在前面注明要操作的列表。就像上面的例子,我们要操作classmates这个列表,所以必须写成 classmates.append() 或 classmates.insert() ,如果不这么写,计算机就不知道你要往哪个列表中加入元素。

没有特殊情况的话,推荐使用append()函数添加元素,因为使用append的时候,元素默认加在列表尾部,不会造成其他元素索引值的改变。如果使用insert的话,就像上面的insert(1,'Tom'),在位置1插入'Tom'后,Tom后面所有的元素,索引值都加了一个1,列表中元素越多,受影响的程度越大,因此使用append()函数要比insert()函数更快。

删除列表中元素的方法有三种

del后面需要用索引的方式表明要删除的元素,也就是上面的例子,names[1]代表names中的第二个元素,使用del即可删除

list.pop() 函数与del差不多,都是使用索引值进行删除,只不过写法不同。

我们可以发现,执行 names.pop(1) 后,python shell打印出了第二个元素的值,也就是我们要删除的那个值,这是因为 pop() 这个函数,是有返回值的,有时候我们需要使用这个值,这个时候就可以用变量存起来。

这样我们就可以通过调用a而使用刚才删掉的元素了。

list.remove() 函数的作用是删除第一个匹配的元素,上面的例子中,names这个列表里面,有两个'Bob',remove函数只删除了第一个'Bob'。这就是 list.remove() 函数的特点。

有时候我们想使用列表的前10个元素,或者前n个元素,这时候就应该使用列表的切片。

切片和索引类似,都是使用中括号,区别是,索引中的中括号里面只有一个数,而切片不同。切片是切割列表,形成切割下来的部分形成新的列表。

切片: list[start:end:[step=1]] ,这就是切片的表达式,要求start和end两者必须有一个,step不是可以不指定,不指定的时候默认为1。

切片该怎么理解呢,start就是开始的位置,end就是结束的位置。切片有个特点是“取前不取后”,看上面那个例子可以发现,1作为start,3作为end,1代表第二个元素,3代表第四个元素,列表切片的时候,是不取后面的那个数字对应的元素的,也就是不取第四个元素,所以names[1:3]只取了第二个元素和第三个元素,这就是所谓的取前不取后。

再看下一个例子。

当不指定start或者end的时候,start默认为0,end默认为最后一个元素的索引值+1,因为“取前不取后”,要想取到最后一个元素,必须加个1才行。

上例中,用 len(numbers) 表示了最后一个元素的索引值,因为索引值从0开始,最后一个元素的索引值一定是列表内元素个数-1,根据“取前不取后”,在end位置上的数字应该+1,所以最后就等于 len(numbers) 了。

当不设定start和end的时候,就默认取所有的元素了。

当加入step,这个选项后,step代表步长,默认为1,设定成2的时候,就是隔一个取一个,设定成3时就是隔两个取一个。

上例中,第一个切片,start和end均未设定,因此从第一个元素开始,隔一个取一个,得到了所有奇数位置的元素。

第二个切片,start设定为了1,因此取了所有偶数位置的元素。

3在列表中,0不在列表中,所以 3 in a 是True,而 0 in a 是False

更多关于列表的信息可以通过使用 help(list) 查看帮助文档。

python如何定义一个函数求列表各项数据平均值?

# coding = GBK

a =[1,2,3,4,5]

sum=0

b = len(a)

print("这个数组的长度为:",b)

for i  in a:

sum =sum +i

print("这个数组之和为:",sum)

print("这个数组平均数为",sum/b)

import sys

sum = 0

cnt = 0

f = open('1.txt', 'r')

files = f.readline()

while (files ):

sum = sum + float(files .split(",")[0])

cnt = cnt + 1

files = f.readline()

print(sum / cnt)

f.close()

或者。

#!/usr/bin/env pythonimport timeimport numpy as np

dd = np.random.randint(0, 20, size=(2*1000*1000))t_start = time.clock()avg_sum1 =

0.0BlockOffset = 0     while BlockOffset len(dd):

if dd[BlockOffset + 1] = 10:

avg_sum1 += dd[BlockOffset + 1] * 0.1

else:

avg_sum1 += dd[BlockOffset + 0] * 0.01

BlockOffset += 2print('Avg: ' + str(avg_sum1 / len(dd) / 2))    print('Exe time: ' +

str(time.clock() - t_start))

扩展资料:

python 实现求和、计数、最大最小值、平均值、中位数、标准偏差、百分比。

import sys

class Stats:

def __init__(self, sequence):

# sequence of numbers we will process

# convert all items to floats for numerical processing

self.sequence = [float(item) for item in sequence]

def sum(self):

if len(self.sequence)  1:

return None

else:

return sum(self.sequence)

def count(self):

return len(self.sequence)

def min(self):

if len(self.sequence)  1:

return None

else:

return min(self.sequence)

def max(self):

if len(self.sequence)  1:

return None

else:

return max(self.sequence)

def avg(self):

if len(self.sequence)  1:

return None

else:

return sum(self.sequence) / len(self.sequence) 

def median(self):

if len(self.sequence)  1:

return None

else:

self.sequence.sort()

return self.sequence[len(self.sequence) // 2]

def stdev(self):

if len(self.sequence)  1:

return None

else:

avg = self.avg()

sdsq = sum([(i - avg) ** 2 for i in self.sequence])

stdev = (sdsq / (len(self.sequence) - 1)) ** .5

return stdev

def percentile(self, percentile):

if len(self.sequence)  1:

value = None

elif (percentile = 100):

sys.stderr.write('ERROR: percentile must be 100.  you supplied: %s\n'% percentile)

value = None

else:

element_idx = int(len(self.sequence) * (percentile / 100.0))

self.sequence.sort()

value = self.sequence[element_idx]

return value

参考资料来源:百度百科-python


网站标题:python列表操作函数 Python列表操作
分享URL:http://myzitong.com/article/dodpghs.html