python学习——基础(四)

在Python中,代码不是越多越好,而是越少越好。代码不是越复杂越好,而是越简单越好。

切片:

L = [‘Michael‘, ‘Sarah‘, ‘Tracy‘, ‘Bob‘, ‘Jack‘]
print L[0:3] # [‘Michael‘, ‘Sarah‘, ‘Tracy‘]

L[0:3]
表示,从索引0开始取,直到索引3为止,但不包括索引3。即索引0,1,2,正好是3个元素。
如果第一个索引是0,还可以print L[:3]

同时可以设置步长:

L = range(100)
print L[10:20:2] # 最后一个2表示每隔2隔取一个值
print L[::5] # 所有数每隔5隔取一个
print L[:] # 原样复制一个list

tuple = (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10) #tuple也可以切片
print tuple[:3]

print ‘ABCDEFG‘[:3] # 字符串也可以进行切片
print ‘ABCDEFG‘[::2]

按照从左边开始到右边截止的交集,否则为空。

迭代:

在Python中,迭代是通过for ... in来完成的;当我们使用for循环时,只要作用于一个可迭代对象,for循环就可以正常运行,而我们不太关心该对象究竟是list还是其他数据类型;那么,如何判断一个对象是可迭代对象呢?方法是通过collections模块的Iterable类型判断:

from collections import Iterable

print isinstance(‘abc‘, Iterable) # True
print isinstance([1, 2, 3], Iterable) # True
print isinstance((1, 2, 3), Iterable) # True
print isinstance({‘java‘: ‘diff‘, ‘python‘: ‘middle‘}, Iterable) # True

同时可以获取可迭代对象元素的下标:

for i, key in enumerate([‘a‘, ‘b‘, ‘c‘]):
    print i,key

0 a
1 b
2 c

for x, y in [(1, 1), (2, 4), (3, 9)]:
    print x, y

1 1
2 4
3 9

列表生成式:

print [x*x for x in  range(1, 11)]
# [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

print [x*x for x in range(1, 11) if x % 2 ==0]
# [4, 16, 36, 64, 100],在list里面可以用if语句进行刷选

print [m+n for m in ‘ABC‘ for n in ‘XYZ‘]
# [‘AX‘, ‘AY‘, ‘AZ‘, ‘BX‘, ‘BY‘, ‘BZ‘, ‘CX‘, ‘CY‘, ‘CZ‘]

L = [‘Hello‘, ‘World‘, 18, ‘Apple‘, None]
print [x.lower() if isinstance(x, str)else x for x in L ]
# [‘hello‘, ‘world‘, 18, ‘apple‘, None],在条件表达式中进行筛选

生成器:

通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了。

所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间。在Python中,这种一边循环一边计算的机制,称为生成器(Generator)。

创建L
和g
的区别仅在于最外层的[]
和()
,L
是一个list,而g
是一个generator。

s = (x*x for x in range(1, 11))
print [m for m in s] # 通过for循环遍历出generator的内容

另一种生成generator的方法:

def odd():
    print ‘step 1‘
    yield 1
    print ‘step 2‘
    yield 3
    print ‘step 3‘
    yield 5

print odd()

print [m for m in odd()]

结果:

<generator object odd at 0x0262D3A0>
step 1
step 2
step 3
[1, 3, 5]

变成generator的函数后,在每次调用next()
的时候执行,遇到yield
语句返回,再次执行时从上次返回的yield
语句处继续执行。

时间: 2024-10-21 03:02:49

python学习——基础(四)的相关文章

Python学习基础篇第一篇——快速入门(适合初学者)

一.Python学习基础篇第一篇--(快速入门) 建议从Python2.7开始学习,Python2.7可以支持扩展大量的第三方类库,是目前比较成熟的版本 编写代码的软件推荐将python自带的IDLE和PyCharm集成IDE结合起来使用 1.1 Python命令行 Python命令行将以 >>> 开始,比如 >>>print 'Hello World!' 对于验证简单的命令可以在python自带的IDLE中完成  1.2 在Python自带的IDLE写一段小程序 在所

python学习第四十八天json模块与pickle模块差异

在开发过程中,字符串和python数据类型进行转换,下面比较python学习第四十八天json模块与pickle模块差异. json 的优点和缺点 优点  跨语言,体积小 缺点 只能支持 int str list tuple dict pickle 的优点和缺点 优点 专门为python设计,支持python所有的数据类型 缺点 只能python使用,存储数据占空间大 文章来自 www.96net.com.cn 原文地址:https://www.cnblogs.com/96net/p/97806

Python学习第四天学习写的小案例(主要是针对 分支/循环的学习)

Python学习第四天学习写的小案例 (2019/07/17) 第一题:使用while循环输出1 2 3 4 5 6 8 9 10 程序代码: s = 0 while s<10: if s==6: s += 1 # 当数字为7的时候输出一个空格出来 print(end=' ') continue s += 1 print(s,end=' ') 运行结果: 1 2 3 4 5 6 8 9 10 第二题: 求1-100的所有数的和 程序代码: count = 0 for i in range(101

python学习-第四天补充-面向对象

python学习-第四天补充-面向对象 python 私有 --name mangling(名字修改.名字) 在命名时,通过使用两个下划线作为开头,可以使得这个变量或者函数编程私有的,但是这个其实的python的伪私有,实际是python通过名字修改来进行的,python会把这样命名的变量或者函数名改为_类名__变量名 class A: __name="hello" t = A(); #print(t.__name) #这样会出现错误,错误提示说这个变量没有__name类型 print

[Python学习] 专题四.文件基础知识

        前面讲述了函数.语句和字符串的基础知识,该篇文章主要讲述文件的基础知识(与其他语言非常类似). 一. 文件的基本操作         文件是指存储在外部介质(如磁盘)上数据的集合.文件的操作流程为: 打开文件(读方式\写方式)->读写文件(read\readline\readlines\write\writelines)->关闭文件 1.打开文件 调用函数open打开文件,其函数格式为: file_obj=open(filename[, mode[, buffering]])

python学习第四十二天:前端基础

前端学习? 1.HTML是什么? HTML,全称"Hyper Text Markup Language(超文本标记语言)",简单来说,网页就是用HTML语言制作的.HTML是一门描述性语言,是一门非常容易入门的语言. 2.CSS是什么? CSS,全称"(层叠样式表)".以后我们在别的地方看到"层叠样式表"."CSS样式",指的就是CSS. 3.JavaScript? JavaScript是一门脚本语言. HTML基本语法 语法

《转》python学习--基础上

学习的python本来想自己总结,但是发现了一篇不错的大牛的博客,拿来主义,,又被我实践了 关于前两篇如果总结的不详细,因此把他人的转载过来 http://www.cnblogs.com/BeginMan/archive/2013/04/12/3016323.html 一.欲练此功,必先自宫 从现在起,就开始真正地接触她了,或许很多人像我一样,不知道如何去快速掌握一门新的编程语言,今天贴出来一些建议,方便大家看看,这也是学习之前的十分重要的事情.虽然"欲练此功,必先自宫"太夸张,但是在

我的python学习--第四天

一.首先是对前三天的学习内容进行复习 1.python基础的数据结构 数字(int/float,包括整数和浮点数) 布尔(boolean => True/False) 字符串(str,使用''或""括起来) 列表(list) 列表是使用[]括起来的一组数组,在内存中是连续的,可以对其增删改查 字典(dict) 字典是使用{}括起来的k/v键值对,经过哈希计算随机分布在内存中,是无序的,可以对其增删改查 元组(tuple) 元组与列表类似,不同之处在于元组的元素不能修改,元组使用小

Python学习-基础篇1

一.变量: 1)变量定义规范: #1. 变量名只能是 字母.数字或下划线的任意组合#2. 变量名的第一个字符不能是数字#3. 关键字不能声明为变量名['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda',