-- coding: utf-8 --

@Time : 2019/11/6 9:06

@Author : Nix Chen

@File : demo9_20191106.py

@Software: PyCharm

列表

列表是Python中内置有序可变序列,所有元素放在[],每个元素使用逗号可开

创建列表

list1 = ['鲁班', '安琪拉', '狄仁杰', ['科比', '乔丹', '詹姆斯'], 111, 99.9]

# 列表的访问

# 列表名[index]

print(list1[3]) # ['科比', '乔丹', '詹姆斯']

print(list1[3][1]) # 乔丹

查看列表里的元素个数

print(len(list1)) # 6

列表的添加

append 向列表的尾部增加一个元素,不改变其内存首地址,属于原地操作

list1.append(['1', '2', '3'])

print('添加后列表的值是', list1)

# 添加后列表的值是 ['鲁班', '安琪拉', '狄仁杰', ['科比', '乔丹', '詹姆斯'], 111, 99.9, ['1', '2', '3']]

insert(self,index,object) 向列表任意位置插入一个元素,不改变其内存首地址,属于原地操作

list1.insert(3, '今天天气还不错')

print('insert添加后列表的值是', list1) # 0, -1, -2

# insert添加后列表的值是 ['鲁班', '安琪拉', '狄仁杰', '今天天气还不错', ['科比', '乔丹', '詹姆斯'], 111, 99.9, ['1', '2', '3']]

extend() 将另一个迭代对象的所有元素添加至该列表对象尾部,不改变其内存首地址,属于原地操作

list1.extend([3, 4, 5])

print('extend添加后列表的值是', list1)

# extend添加后列表的值是 ['鲁班', '安琪拉', '狄仁杰', '今天天气还不错', ['科比', '乔丹', '詹姆斯'], 111, 99.9, ['1', '2', '3'], 3, 4, 5]

print(len(list1)) # 11

列表的 + 和 * 操作

# + 是连接两个列表

x = [1, 2, 3]

y = x +[4] # [1, 2, 3, 4]

print(y)

# * 是复制列表

y = x*2

print(y) # [1, 2, 3, 1, 2, 3]

# 这两个操作并不是真的为列表添加元素,而是创建一个新的列表,不属于原地操作,返回的是新的列表

列表元素的删除

pop() 使用列表的pop()方法删除并且返回指定(默认是最后一个)位置的元素,如果给出的索引超出了list的范围,则会抛出异常

x = [1, 2, 3, 4]

value = x.pop(1)

print(value) # 2

print('删除后的x', x) # 删除后的x [1, 3, 4]

remove 删除首次出现的指定元素,如果列表中不存在要删除的元素,则抛出异常

x = [1, 2, 2, 3, '4']

x.remove(2)

print('remove删除后的x', x) # remove删除后的x [1, 2, 3, '4']

clear()清空列表

x = [1, 2, 2, 3, '4']

x.clear()

print(x) # []

del 删除列表中指定位置的元素,如果列表超出索引范围,则抛出异常

del 列表[index]

x = [1, 2, 2, 2, 3, '4']

del x[5]

print(x) # [1, 2, 2, 2, 3]

列表的元素的基数

x = [1, 2, 2, 2, 3, '4']

# count 统计指定元素在列表中出现的次数

print(x.count(2)) # 3

print(x.count('4')) # 1

print(x.count(0)) # 0

index() 获取指定元素首次出现的下标,若列表对象中不存在指定元素,抛出异常

x = [1, 2, 2, 2, 3, '4']

print(x.index(2)) # 1

# print(x.index(4))

print(x.index(2, 2, 4)) # 2

print(x.index(3, 2, 5)) # 4

in 测试列表是否含有该元素,返回 bool类型

x = [1, 2, 2, 2, 3, '4']

print(4 in x) # False

print(2 in x) # True

print(4 not in x) # True

-- coding: utf-8 --

@Time : 2019/11/6 10:30

@Author : Nix Chen

@File : demo10_20191106.py

@Software: PyCharm

列表的排序

列表的内置方法:列表明.sort()

list1 = []

for x in range(15):

list1.append(x)

print(list1)

print(list1) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]

list1 = []

for x in range(15):

list1.insert(0,x)

print(list1)

print(list1) # [14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0]

list1 = []

for x in range(15):

list1.extend([x])

print(list1)

print(list1) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]

打乱顺序

from random import shuffle

shuffle(list1)

print('打乱顺序后', list1) #打乱顺序后 [8, 14, 1, 10, 3, 2, 11, 13, 7, 6, 5, 4, 9, 12, 0]

list1.sort()

print('排序后', list1) #排序后 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]

list1.sort(reverse=True) #指定为逆序排序

print(list1) # [14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0]

reverse() #将列表中的所有元素原地逆序排序

list1.reverse()

print('排序后', list1) # 排序后 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]

sorted()

内置函数sorted 对列表进行排序并且返回新的列表,不对原来的列表进行修改

list1 = sorted(list1)

print('排序后', list1) #排序后 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]

reversed()

返回一个逆序排序后的迭代对象,不对原来的列表做修改

list1 = list(reversed(list1))

# reversed() 返回的是一个存储地址,需要用内置函数显形

print(list1) # [14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0]

-- coding: utf-8 --

@Time : 2019/11/6 11:09

@Author : Nix Chen

@File : demo11_20191106.py

@Software: PyCharm

用于序列(列表,元组,字符串,[字])操作的常用内置函数

len() 返回序列中元素的个数,适用于元组,列表,字典,集合

x = [1, 2, 3]

print(len(x)) # 3

max() min()

返回序列中最大或最小的元素 同样适用于元组,列表,字典,集合

print(max(x)) # 3

print(min(x)) # 1

sum()对迭代对象求和

print(sum(x)) # 6

zip() 返回可迭代的zip对象

常常用于同时迭代两个列表

heros = ['鲁班', '后羿']

skills = ['无敌鲨鱼炮', '惩戒之箭']

for hero, skill in zip(heros, skills):

print(hero,'------>',skill)

# 鲁班 - -----> 无敌鲨鱼炮

# 后羿 - -----> 惩戒之箭

a = [1, 2, 3]

b = [4, 5, 6]

c = [4, 5, 6, 7, 8, 9]

zipped = zip(a,b)

print(zipped) #

print(list(zipped)) # [(1, 4), (2, 5), (3, 6)]

print(list(zip(a,c))) # 元素个数与最短的一致

zip() 可以理解为解压,返回二维矩阵*

a1, a2 = zip(*zip(a,b))

print(list(zip(*zip(a,b)))) # [(1, 2, 3), (4, 5, 6)]

print(list(a1)) # [1, 2, 3]

print(list(a2)) # [4, 5, 6]

print(a1) #(1, 2, 3)

enumerate # 枚举列表元素,返回枚举对象,其中每个元素包含索引和元素的值

for x in enumerate(['a', 'b', 'c']):

print(x)

遍历列表的三种方式:

l1 = ['a', 'b', 'c', 'd', 'e']

# 1.

for x in l1:

print(x, end=' ')

print() # a b c d e

# 2.

for i in range(len(l1)):

print(l1[i], end=' ')

print() #a b c d e

# 3.

for index,value in enumerate(l1):

print(value, end=' ')

print() #a b c d e

-- coding: utf-8 --

@Time : 2019/11/6 14:06

@Author : Nix Chen

@File : demo12_20191106.py

@Software: PyCharm

列表推导式

列表推导式使用非常简洁的方式来快速生成满足特定需求的列表,代码具有非常强的可读性

语法形式:[返回表达式 for 临时变量 in 序列或迭代对象 条件表达式]

列表推导式在逻辑上相当于一个for循环,只是形式更加简洁.

# li = [0, 1, ......,9]

li = []

for i in range(10):

li.append(i)

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

# [返回表达式 for 临时变量 in 序列或迭代对象 条件表达式]

print([i for i in range(10)]) #[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

列表的嵌套

L = [[1, 2, 3],[4, 5, 6],[7, 8, 9]]

平铺这个列表

result = []

for l in L:

for x in l:

result.append(x)

print(result)

print('--'*20)

print(result) # [1, 2, 3, 4, 5, 6, 7, 8, 9]

使用列表推导式对列表进行平铺

print([str(x) for l in L for x in l]) # [1, 2, 3, 4, 5, 6, 7, 8, 9]

print([i for l in L for i in l]) # [1, 2, 3, 4, 5, 6, 7, 8, 9]

过滤不符合条件的元素

[返回表达式 for 临时变量 in 序列或迭代对象 条件表达式]

from random import randint # 生成给定范围的随机数

# _下划线的目的是增强代码的可读性,告诉读代码的人这里不需要使用临时变量

l2 = [randint(-20, 20) for _ in range(10)]

print(l2) # [14, 9, 7, 1, -8, 7, -6, -17, 8, -14]

# 使用列表推倒式,筛选出所有大于0的元素

print([elem for elem in l2 if elem >0]) # [14, 9, 7, 1, 7, 8]

print(list(elem for elem in l2 if elem >0)) # [14, 9, 7, 1, 7, 8]

-- coding: utf-8 --

@Time : 2019/11/6 14:40

@Author : Nix Chen

@File : home_works_20191106.py.py

@Software: PyCharm

分页实现内容

# a.通过for循环创建301条数据,数据类型不限,如:

# zhangsan-1 zhangsan1@neuedu.com pwd1

# zhangsan-2 zhangsan2@neuedu.com pwd2

# zhangsan-3 zhangsan3@neuedu.com pwd3

# ...

# 提示用户 请输入要查看的页码,当用户输出指定页码,也显示指定数据

# 注意:

# 每页显示10条数据

#

# 比如:

# 请输入要查看的页码:5

# ['zhangsan41', 'zhangsan41@neuedu.com', 'pwd41']

# ['zhangsan42', 'zhangsan42@neuedu.com', 'pwd42']

# ['zhangsan43', 'zhangsan43@neuedu.com', 'pwd43']

# ['zhangsan44', 'zhangsan44@neuedu.com', 'pwd44']

# ['zhangsan45', 'zhangsan45@neuedu.com', 'pwd45']

# ['zhangsan46', 'zhangsan46@neuedu.com', 'pwd46']

# ['zhangsan47', 'zhangsan47@neuedu.com', 'pwd47']

# ['zhangsan48', 'zhangsan48@neuedu.com', 'pwd48']

# ['zhangsan49', 'zhangsan49@neuedu.com', 'pwd49']

# ['zhangsan50', 'zhangsan50@neuedu.com', 'pwd50']

# 请输入要查看的页码:12

# ['zhangsan111', 'zhangsan111@neuedu.com', 'pwd111']

# ['zhangsan112', 'zhangsan112@neuedu.com', 'pwd112']

# ['zhangsan113', 'zhangsan113@neuedu.com', 'pwd113']

# ['zhangsan114', 'zhangsan114@neuedu.com', 'pwd114']

# ['zhangsan115', 'zhangsan115@neuedu.com', 'pwd115']

# ['zhangsan116', 'zhangsan116@neuedu.com', 'pwd116']

# ['zhangsan117', 'zhangsan117@neuedu.com', 'pwd117']

# ['zhangsan118', 'zhangsan118@neuedu.com', 'pwd118']

# ['zhangsan119', 'zhangsan119@neuedu.com', 'pwd119']

# ['zhangsan120', 'zhangsan120@neuedu.com', 'pwd120']

while True:

page = int(input('请输入查询页数:'))

Num_mix =page*10-9

Num_max = page*10+1

name_list = ['zhangsan-{}'.format(i) for i in range(Num_mix, Num_max)]

# print(name_list)

email_list = ['zhangsan{}@neuedu.com'.format(i) for i in range(Num_mix, Num_max)]

# print(email_list)

psw_list = ['pwd{}'.format(i) for i in range(Num_mix, Num_max)]

# print(psw_list)

zipped = zip(name_list, email_list, psw_list)

main_list = list(zipped)

# print(main_list)

if 0 < page <=30:

for x in main_list:

print(x[0], x[1], x[2])

elif page == 31:

print('zhangsan-301, zhangsan301@neuedu.com, pwd301')

else:

print('超出范围')

python基本符合_python 3-3(2019-11-06 ) Python基础 (三)相关推荐

  1. python历史背景_python学习之旅1-1(python背景、安装介绍)

    一.python介绍 1.python历史背景 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆(中文名字:龟叔)为了在阿姆斯特丹打发时 ...

  2. 【豆瓣电影】2019/11/21/Python搜索豆瓣电影(Top100)爬虫+D3.js词云(票房和豆瓣评分)实现

    [豆瓣电影爬虫]2019/11/21/Python豆瓣电影爬虫+D3.js WordCloud 1.目标 今天临时需要将100部票房最高的电影[from艺恩网:如图1],找到对应的豆瓣评分,制作D3词 ...

  3. python自动化教程_Python自动化开发实战视频课程-全新基础篇_Python教程

    教程名称:Python自动化开发实战视频课程-全新基础篇 课程目录: 0001.51CTO学院-01Pythons10 day1 开课前言- _* N, R+ w/ T 0001.51CTO学院-01 ...

  4. 有哪些免费自学python的网站_Python学习网站有哪些?Python基础教程网站推荐

    Python学习网站有哪些?Python基础教程网站推荐:菜鸟教程.PHP中文网.PHP中文网.W3C.Reddit.博学谷.python中文学习大本营.Python 3 Module of the ...

  5. python语言画心_python语言还是java如何用python画爱心

    用python绘制爱心的基本步骤如下: 002pc.com对<python语言还是java如何用python画爱心>总结来说,为我们学习Python很实用. 首先先下载安装好python程 ...

  6. python自增_Python的自增运算与Python变量的浅析

    一.关于Python的自增运算 学了C/C++后再学习Python,不自觉地就打出了自增运算符++,但是发现Python解释器不认识,查了下资料,发现Python中没有这个运算符.这里暂时不探讨自增运 ...

  7. python计算存款_python入门教程NO.8 用python写个存款利息计算器

    本文涉及的python基础语法为def函数,return,函数的各参数示例,匿名函数等 函数初识 函数是一段组织好的 可重复使用的 用来实现特定功能的代码块. 函数能提高代码的模块性,和代码的重复利用 ...

  8. linux和python那个好学_Python和C#哪个好学?老男孩python

    现在编程语言有很多种,大家在选择的时候可能会疑惑该学习哪个编程语言呢?Python和C#哪个好学?接下来老男孩教育为大家详细介绍一下. python是一种跨平台语言,无论是Windows.Linux. ...

  9. python 东方财富接口_Python从东方财富网站获取数据,python,的

    python 获取东方财富网站的数据 #!/usr/bin/env python # -*- coding: utf-8 -*- import pandas as pd from selenium i ...

最新文章

  1. 【设计模式】—— 职责链模式ChainOfResponsibility
  2. html 页面友情提示,HTML参考
  3. 百万数据报表导出:原理分析与总结
  4. Storm的ack机制在项目应用中的坑
  5. 拖动无边框的登入窗口
  6. 使用Nagios打造专业的业务状态监控
  7. 公众号发布代码最好的工具markdown语法
  8. 安装Nagios监控软件
  9. c语言linux系统宏,Linux下C语言中的预定义宏
  10. Dreamweaver制作漂亮的网页Flash电子相册
  11. 【Python实战系列】串口实时接收数据并基于pyqtgraph绘图
  12. python版本AES CBC 模式ECA加密逻辑
  13. coreldraw怎样定数等分_coreldraw 里怎么将线段等分?
  14. Web前端HTML使用
  15. python实现gui+mysql图书管理系统_用Python Django框架写一个图书管理系统LMS
  16. 仿人人客户端向右滑出式菜单
  17. Python:打包生成.pyc、.pyd文件
  18. 极限中0除以常数_基本不等式中常用公式百度作业帮
  19. mysql pt工具 加索引_[转]MySQL中如何为连接添加索引
  20. 大公司研发部门普遍存在的问题(日常吐槽)

热门文章

  1. 玩大了!别再埋头学Python了,它真的无用!
  2. 泪目!连拿3份 offer,AI 程序员求职经历火爆 IT圈!
  3. 项目实战Git团队操作_图形化版本
  4. centos7安装rabbitmq简单方式
  5. 3个点让你彻底明白,为什么要使用MQ消息中间件?
  6. SpringBoot2整合Activiti6工作流框架 源码
  7. Spring概念理解
  8. Vue+mui实现图片的本地缓存
  9. python print用法不换行_python3让print输出不换行的方法
  10. qt使用动画提示正在载中