一篇文章带你学习Python3的高级特性(1)

 更新时间:2022年01月25日 11:21:13   作者:FUXI_Willard  
这篇文章主要为大家详细介绍了Python3的高阶函数,主要介绍什么是高级特性,高级特性的用法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

1.切片

# 切片:取list或tuple的部分元素
nameList = ["Willard","ChenJD","ChenBao","ChenXiaoBao","hackerLuo"]
print("nameList的内容为:",nameList)
print("------------------------------------------------------------------------------")
# 传统方法取nameList前三个元素
print("nameList前三个元素:",[nameList[0],nameList[1],nameList[2]])
print("------------------------------------------------------------------------------")
# 使用切片取前三个元素,注:切片也是左闭右开
print("使用切片操作取nameList前三个元素:",nameList[0:3])
print("使用切片操作取nameList第二个到第四个元素:",nameList[1:5])
print("------------------------------------------------------------------------------")
print("------------------------------------------------------------------------------")
# 切片的一些常用操作
numsList = list(range(30))
print("数字列表内容为:\n",numsList)
print("------------------------------------------------------------------------------")
print("数字列表前10个数内容:",numsList[0:10])
print("数字列表前10个数内容:",numsList[:10])
print("\n")
print("数字列表后10个数内容:",numsList[-10:])
print("数字列表前11-20个数内容:",numsList[10:20])
print("数字列表前10个数每隔两个取一个:",numsList[0:10:2])
print("数字列表前10个数每隔两个取一个:",numsList[:10:2])
print("数字列表每隔3个数取一个:",numsList[::3])
print("数字列表内容:\n",numsList[:])
# Tips:
# 1.tuple可以使用切片操作,操作的结果仍是tuple;
# (0,1,2,3,4,5)[:3]  ===>  (0,1,2)
# 2.字符串使用切片操作,一个字符就是一个元素
# "Welcome to FUXI Technology."[:3]  ===>  "Wel"

# 结果输出:
nameList的内容为: ['Willard', 'ChenJD', 'ChenBao', 'ChenXiaoBao', 'hackerLuo']
------------------------------------------------------------------------------
nameList前三个元素: ['Willard', 'ChenJD', 'ChenBao']
------------------------------------------------------------------------------
使用切片操作取nameList前三个元素: ['Willard', 'ChenJD', 'ChenBao']
使用切片操作取nameList第二个到第四个元素: ['ChenJD', 'ChenBao', 'ChenXiaoBao', 'hackerLuo']
------------------------------------------------------------------------------
------------------------------------------------------------------------------
数字列表内容为:
 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29]
------------------------------------------------------------------------------
数字列表前10个数内容: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
数字列表前10个数内容: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]


数字列表后10个数内容: [20, 21, 22, 23, 24, 25, 26, 27, 28, 29]
数字列表前11-20个数内容: [10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
数字列表前10个数每隔两个取一个: [0, 2, 4, 6, 8]
数字列表前10个数每隔两个取一个: [0, 2, 4, 6, 8]
数字列表每隔3个数取一个: [0, 3, 6, 9, 12, 15, 18, 21, 24, 27]
数字列表内容:
 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29]
 

2.迭代

# 给定一个list或tuple,通过for循环来遍历这个list或tuple,这种遍历称为迭代(iteration);# 迭代通过for...in来完成;# 实例1:迭代dictpersonInfoDict = {"name":"Willard","age":18,"job":"Engineer"}print("使用迭代读取dict内容!")print("personInfoDict的内容:",personInfoDict)print("------------------------------------------------------------------------------")# 读取personInfoDict的key值print("personInfoDict的key值:")for key in personInfoDict:    print(key,end = " ")print("\n")print("personInfoDict的value值:")for value in personInfoDict.values():    print(value,end = " ")    print("\n")print("personInfoDict的key-value值:")for item in personInfoDict.items():    print(item,end = " ")print("\n")print("------------------------------------------------------------------------------")print("------------------------------------------------------------------------------")# 实例2:迭代读取字符串userNameStr = "WillardLuo"print("使用迭代读取字符串内容!")print("userNameStr的内容:",userNameStr)print("------------------------------------------------------------------------------")print("userNameStr的每个元素为:")for word in userNameStr:    print(word,end = " ")# 给定一个list或tuple,通过for循环来遍历这个list或tuple,这种遍历称为迭代(iteration);
# 迭代通过for...in来完成;
# 实例1:迭代dict
personInfoDict = {"name":"Willard","age":18,"job":"Engineer"}
print("使用迭代读取dict内容!")
print("personInfoDict的内容:",personInfoDict)
print("------------------------------------------------------------------------------")
# 读取personInfoDict的key值
print("personInfoDict的key值:")
for key in personInfoDict:
    print(key,end = " ")
print("\n")
print("personInfoDict的value值:")
for value in personInfoDict.values():
    print(value,end = " ")
print("\n")
print("personInfoDict的key-value值:")
for item in personInfoDict.items():
    print(item,end = " ")
print("\n")
print("------------------------------------------------------------------------------")
print("------------------------------------------------------------------------------")
# 实例2:迭代读取字符串
userNameStr = "WillardLuo"
print("使用迭代读取字符串内容!")
print("userNameStr的内容:",userNameStr)
print("------------------------------------------------------------------------------")
print("userNameStr的每个元素为:")
for word in userNameStr:
    print(word,end = " ")

# 结果输出:
使用迭代读取dict内容!
personInfoDict的内容: {'name': 'Willard', 'age': 18, 'job': 'Engineer'}
------------------------------------------------------------------------------
personInfoDict的key值:
name age job 

personInfoDict的value值:
Willard 18 Engineer 

personInfoDict的key-value值:
('name', 'Willard') ('age', 18) ('job', 'Engineer') 

------------------------------------------------------------------------------
------------------------------------------------------------------------------
使用迭代读取字符串内容!
userNameStr的内容: WillardLuo
------------------------------------------------------------------------------
userNameStr的每个元素为:
W i l l a r d L u o  

# Tips:
# 1.使用for...in循环需要作用于一个可迭代对象;
# 2.判断一个对象是否是可迭代对象,可通过collections.abs模块的Iterable类型判断
from collections.abc import Iterable
nameStr = "WillardLuo"
nameList = ["Willard","ChenJD","ChenBao"]
numberTuple = (1,2,3,4,5)
personInfoDict = {"name":"Willard","age":18}
number = 100
print("判断字符串是否是可迭代对象!")
print(isinstance(nameStr,Iterable))
print("判断列表是否是可迭代对象!")
print(isinstance(nameList,Iterable))
print("判断元组是否是可迭代对象!")
print(isinstance(numberTuple,Iterable))
print("判断字典是否是可迭代对象!")
print(isinstance(personInfoDict,Iterable))
print("判断数字是否是可迭代对象!")
print(isinstance(number,Iterable))
print("------------------------------------------------------------------------------")
print("------------------------------------------------------------------------------")
# 实现对list进行下标循环
# 使用enumerate函数把一个list变成"索引-元素"对
nameList = ["Willard","ChenJD","ChenBao","ChenXiaoBao","hackerLuo"]
for index,value in enumerate(nameList):
    print(index,value)
    
print("------------------------------------------------------------------------------")
willardInfo = {"name":"Willard","age":18,"job":"Engineer"}
# 循环中同时引用两个变量,数据处理中常用
for key,value in willardInfo.items():
    print(key,value)

# 结果输出:
判断字符串是否是可迭代对象!
True
判断列表是否是可迭代对象!
True
判断元组是否是可迭代对象!
True
判断字典是否是可迭代对象!
True
判断数字是否是可迭代对象!
False
------------------------------------------------------------------------------
------------------------------------------------------------------------------
0 Willard
1 ChenJD
2 ChenBao
3 ChenXiaoBao
4 hackerLuo
------------------------------------------------------------------------------
name Willard
age 18
job Engineer
 

3.列表生成式

# 列表生成式:List Comprehensions,用来创建list的生成式
# 实例1:生成[1×1,2×2,3×3,...,10×10]的列表
# 法一:循环
numsList = []
for num in range(1,11):
    numsList.append(num * num)
print("numsList的内容:",numsList)
print("---------------------------------------------------------")
# 法二:列表生成式
print("列表生成式生成上述列表!")
# 把要生成的元素放在前面,后面加循环
print([num * num for num in range(1,11)])
print("---------------------------------------------------------")
# 在循环后添加if判断,筛选1-10中偶数的平方
print("列表生成式生成1-10偶数的平方的列表")
print([num * num for num in range(1,11) if num % 2 == 0])
print("---------------------------------------------------------")
# 双重循环
print("列表生成式应用于双重循环")
print([m + n for m in "Willard" for n in "ChenJD"])

# 结果输出:
numsList的内容: [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
---------------------------------------------------------
列表生成式生成上述列表!
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
---------------------------------------------------------
列表生成式生成1-10偶数的平方的列表
[4, 16, 36, 64, 100]
---------------------------------------------------------
列表生成式应用于双重循环
['WC', 'Wh', 'We', 'Wn', 'WJ', 'WD', 'iC', 'ih', 'ie', 'in', 'iJ', 'iD', 'lC', 'lh', 'le', 'ln', 'lJ', 'lD', 'lC', 'lh', 'le', 'ln', 'lJ', 'lD', 'aC', 'ah', 'ae', 'an', 'aJ', 'aD', 'rC', 'rh', 're', 'rn', 'rJ', 'rD', 'dC', 'dh', 'de', 'dn', 'dJ', 'dD']
 

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • Python 异步之非阻塞流使用示例详解

    Python 异步之非阻塞流使用示例详解

    这篇文章主要为大家介绍了Python 异步之非阻塞流使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Python实现将DNA序列存储为tfr文件并读取流程介绍

    Python实现将DNA序列存储为tfr文件并读取流程介绍

    为什么要在实验过程中存储文件,因为有些算法的内容存在一些重复计算的步骤,这些步骤往往消耗很大一部分时间,在有大量参数的情况时,需要在多次不同参数的情况下重复试验,因此可以考虑将一些不涉及参数运算的部分结果存入文件中
    2022-09-09
  • python包导入的两种方式

    python包导入的两种方式

    本文主要介绍了python包导入的方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • 如何在Python里使用ChatGPT及ChatGPT简介

    如何在Python里使用ChatGPT及ChatGPT简介

    今年最火的应该就是ChatGPT了,现在短短2个月已经突破了1亿注册用户,马斯克可高兴坏了,这篇文章主要介绍了如何在Python里使用ChatGPT及ChatGPT是什么?注册方式?需要的朋友可以参考下
    2023-02-02
  • Python的pytest测试框架使用详解

    Python的pytest测试框架使用详解

    这篇文章主要介绍了Python的pytest测试框架使用详解,说到 pytest,大家总不免要拿来和 unittest 来比一下,但是 unittest 毕竟是标准库,兼容性方面肯定没得说,但要论简洁和方便的话,pytest 也是不落下风的,需要的朋友可以参考下
    2023-07-07
  • Python的Django框架中使用SQLAlchemy操作数据库的教程

    Python的Django框架中使用SQLAlchemy操作数据库的教程

    SQLAlchemy是Python一个专门的数据库管理工具,如果对Django ORM觉得有些生疏的话完全可以结合SQLAlchemy,这里我们就来总结一下Python的Django框架中使用SQLAlchemy操作数据库的教程
    2016-06-06
  • 微软开源最强Python自动化神器Playwright(不用写一行代码)

    微软开源最强Python自动化神器Playwright(不用写一行代码)

    这篇文章主要介绍了微软开源最强Python自动化神器Playwright(不用写一行代码),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • python实现手机通讯录搜索功能

    python实现手机通讯录搜索功能

    这篇文章主要介绍了python模仿手机通讯录搜索功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • Python cv2 图像自适应灰度直方图均衡化处理方法

    Python cv2 图像自适应灰度直方图均衡化处理方法

    今天小编就为大家分享一篇Python cv2 图像自适应灰度直方图均衡化处理方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-12-12
  • Python实现压缩文件夹与解压缩zip文件的方法

    Python实现压缩文件夹与解压缩zip文件的方法

    这篇文章主要介绍了Python实现压缩文件夹与解压缩zip文件的方法,涉及Python使用zipfile模块进行zip文件压缩与解压缩相关操作技巧,需要的朋友可以参考下
    2018-09-09

最新评论