【Hello Python World】Class Notes of Week 2

2024-08-30 08:58
文章标签 python class hello world notes week

本文主要是介绍【Hello Python World】Class Notes of Week 2,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 列表 (3.14 update)
      • 1.数组下标错误会抛出异常(与C++不同)
      • 2.一个list里可以有不同的数据结构
      • 3.插入方法
      • 4.删除方法
        • 第一种方法:pop(),有返回值
        • 第二种方法:del,没有返回值
        • 第三种方法:remove(),没有返回值,而且会抛出异常
      • 5.操作方法
        • 用sort()和sorted()从小到大排序
        • 翻转列表reverse()
        • 求长度len()
      • 6.列表的数据处理
        • 求和sum()和范围函数range()
        • 求极值min()和max()
      • 7.通过列表解析来生成列表
      • 8.列表切片
      • 9.列表复制辨析
        • 片面地复制:用=
        • 全面地复制:new_list = list[:]
      • 10.元组:只读的列表,被阉割了列表的编辑操作
      • 11.题外话:如何使print()不换行?

列表 (3.14 update)

1.数组下标错误会抛出异常(与C++不同)

li = [1,2,3,4,5]的下标范围是[-5,···,-1,0,4],越界会马上报错(C++不会)

2.一个list里可以有不同的数据结构

li = [[1,2,3],1,'2']
print(li)
#输出 [[1,2,3],1,'2']
print(1i[0][1])
#输出 2

3.插入方法

li = [['w','j'],'p']
li[0].insert(0,12)
print(li)
#输出 [[12, 'w', 'j'], 'p']

4.删除方法

第一种方法:pop(),有返回值
li = [1,2,3]
x = li.pop(1) # x = 2
print(li)
#输出 [1,3]
#pop是会返回值的
第二种方法:del,没有返回值
li = [1,2,3]
del li[1]
print(li)
#输出 [1,3]

为什么del的用法不是li.del(1)
因为del不是列表特有的方法,就像C++里的deletefree一样

第三种方法:remove(),没有返回值,而且会抛出异常

当我们不知道列表里的某个值的元素的下标是什么,但是又想删除的时候,就使用remove()

li = [1,2,1,3,4]
li.remove(1)
#输出 [2,1,3,4]
li.remove(5)
#抛出异常,输出:ValueError: list.remove(x): x not in list

remove()只能删掉第一个元素,不会重复删除,重复删除需要循环

5.操作方法

sort()sorted()从小到大排序
li = [5,3,6,2,1,9]
print(sorted(li))
#sorted() 返回一个新的列表
#输出 [1,2,3,5,6,9]
print(li)
#输出 [5,3,6,2,1,9]
li.sort()
print(li)
#输出 [1,2,3,5,6,9]

sorted()返回一个临时的新列表,排序不对原列表产生影响,注意是sorted(li)而不是li.sorted()(会报错)
sort()不返回任何东西,对原列表产生操作
li = [5,3]
print(li.sort())
输出:None

如果是不同类型的数据放在同一个列表里面排序,结果会怎么样呢?
li = [5,3,'1']
print(sorted(li))

报错:TypeError: '<' not supported between instances of 'str' and 'int'

翻转列表reverse()
li = [5,3]
print(li.reverse())
#输出:None
#print(reverse(li)) 报错
li.reverse()
print(li)
#输出:[3,5]
求长度len()
li = [5,3]
print(len(li))
#输出:2#print(li.len()) 报错
#print(lens(li)) 报错,没有lens()
#print(length()) 报错:没有length()
#print(size()) 报错:没有size()

len()这样调用的函数称为内置函数,为了使它能适用于不止list的容器,不是list特有的函数,比如

word = 'Hello'
print(len(word))
#输出:5

同理,前面讲到的sorted()也是内置函数

word = 'hello'
print(sorted(word))
#输出:['e', 'h', 'l', 'l', 'o']
#注意,【字符串】已经变成了【字符数组】了

但是字符串里面没有listappend()等类成员,也就是说字符串字符列表是不等价的,虽然说一些list的操作也能用在字符串里面,比如负数的下标

word = 'Hello'
print(word[-1])
#输出:o

6.列表的数据处理

求和sum()和范围函数range()
print( sum( range(1, 101) ) )
#输出 5050

注意:
1. range()的表示方式是左闭右开 [---),右边界要多算一个
2. range()的第三个参数是缺省的,用于指定步长,如

range(1, 20, 2) #步长为2,[1,19]
求极值min()max()
nums = [1,2,3,4,5]
print( min(nums) ) #max同理
#输出 1

7.通过列表解析来生成列表

例如:输出 1 - 10 的平方

nums = [ i ** 2 for i in range(1,11) ]

8.列表切片

当需要访问列表的一部分元素时,可以用list[a:b]来访问区间 [a,b) = [a,b-1] ,返回的也是一个列表,所以可以采用之前的对列表的操作来操作列表。

print(nums[:4]) #这样也是可以的

负数呢?比如求倒数的四个数的和:

print( sum( nums[-4:] ) )

又比如从头开始取,直到倒数第二个(也就是除了最后一个)

print(num[:-1]) #最后一个数是不包含的(开区间)

冒号两端两个数字都可以缺省:

print(nums[:]) #打印整个列表

注意:切片是一个独立于原列表的新列表:

nums = [1,2,3,,4,5]
nums[:].append(6)
print(nums)
#输出 [1,2,3,4,5] 可以看出并不受切片操作的影响

9.列表复制辨析

片面地复制:用=
nums = [1,2,3,4,5]
new_nums = nums
new_nums.append(6)
print(nums) #输出什么呢?
#输出 [1,2,3,4,5,6] !!!!

这个例子说明了Python在列表复制时使用·=是一种类似于“换名”的操作,直接赋值创造出来的列表并不独立
注意:在Python中单个变量的复制就不是换名了:num = 5new_num = num,改new_num不影响num

全面地复制:new_list = list[:]
nums = [1,2,3,4,5]
new_nums = nums[:]
new_nums.append(6)
print(nums)
#输出:[1,2,3,4,5] 可以看出两个列表是独立的,终于正常了

10.元组:只读的列表,被阉割了列表的编辑操作

元组切片是可用的,因为切片并不损伤原始数据

arr = (3,2,1)
print(arr[0:1])
#输出 [3,2]

想对元组动手?那就只能对整体下手:

arr = (3,2,1)
arr = [4,3] #这样并不违反规定

11.题外话:如何使print()不换行?

print()函数的第二个参数被省去,若不想让它换行,就加上, end = "",把默认的换行符改掉,如:

print("Hello", end = "")
print(", world!")
#输出 Hello, world!

这篇关于【Hello Python World】Class Notes of Week 2的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120370

相关文章

Python使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及