python的简单文档

本文详细介绍了Python中的四种主要数据结构——列表、元组、字典和集合。列表是可变的,允许重复元素,支持索引修改、添加、删除等操作;元组不可变,常用于数据打包;字典是键值对的集合,无序且可变,可用于快速查找;集合同样无序,不允许重复元素,支持集合运算如交、并、差。此外,还提到了类和对象的概念。
摘要由CSDN通过智能技术生成

列表(List)

列表是一个有序且可更改的集合。在 Python 中,列表用方括号编写。允许重复的成员。

thislist = ["apple", "banana", "cherry"]    # 索引与元组类似

thislist[1] = "mango"           # 更改项目值
thislist.append("orange")       # 将项目添加到列表的末尾
thislist.insert(1, "orange")    # orange成第二个项目
thislist.remove("banana")       # 删除项目
thislist.pop()                  # 删除指定项目
thislist.clear()                # 清空列表

# 复制列表
mylist = thislist.copy()        
mylist = list(thislist)

# 合并列表
list1 = ["a", "b" , "c"]
list2 = [1, 2, 3]
list3 = list1 + list2
# 或者 追加列表
for x in list2:
  list1.append(x)
list1.extend(list2)         # 将一个列表中的元素添加到另一列表

thislist = list(("apple", "banana", "cherry")) # 创造列表 请注意双括号

元组(Tuple)

元组是有序且不可更改的集合。在 Python 中,元组是用圆括号编写的。允许重复的成员。

thistuple = ("apple", "banana", "cherry", "orange", "kiwi", "melon")

# 负索引表示从末尾开始,-1 表示最后一个项目,-2 表示倒数第二个项目,依此类推。
print(thistuple[-1])
print(thistuple[2:5])       # 返回第3,4,5个项目,从0开始,包括2,不包括5
print(thistuple[-4:-1])     # 包括-4 不包括-1

创建元组后,无法更改其值。但是可以将元组转换为列表,更改列表,然后将列表转换回元组。

x = ("apple", "banana", "cherry")
y = list(x)
y[1] = "kiwi"
x = tuple(y)

字典(Dictionary)

字典是一个无序、可变和有索引的集合。在 Python 中,字典用花括号编写,拥有键和值。没有重复的成员。

thisdict =	{
  "brand": "Porsche",
  "model": "911",
  "year": 1963
}
# 获得键的值
x = thisdict["model"]
x = thisdict.get("model")

thisdict["year"] = 2019     # 更改值

# 判断 字典中是否存在 "model"
if "model" in thisdict:
  print("Yes, 'model' is one of the keys in the thisdict dictionary")

for x in thisdict:
  print(x)                  # 获得所有键名
  print(thisdict[x])        # 获得所有键值

# 获得所有键值
for x in thisdict.values():
  print(x)

# items() 遍历键和值
for x, y in thisdict.items():
  print(x, y)

thisdict["color"] = "red"   # 添加项目
thisdict.pop("model")       # 删除项目
thisdict.clear()            # 清空字典
dict.get(key, default=None)

集合(Set)

集合是无序和无索引的集合。在 Python 中,集合用花括号编写。没有重复的成员。无法通过引用索引来访问 set 中的项目
集合一旦创建,无法更改项目,但是添加新项目。

thisset = {"apple", "banana", "cherry"}
thisset = set(("apple", "banana", "cherry"))

thisset.add("orange")           # 将一个项添加到集合
thisset.update(["orange", "mango", "grapes"])   # 向集合中添加多个项目

# 删除项目,有多种方法
thisset.remove("banana")        # 如果要删除的项目不存在,报错
thisset.discard("banana")       # ~,不会引发错误
x = thisset.pop()               # 删除最后一项,但因为set无序,所以是随机删的,返回被删的值

set3 = set1.union(set2)         # 合并集合
set1.update(set2)               # 这两种都将排除任何重复项

集合的交并差运算

set1 = {1, 2, 3, 4, 5, 6, 7}
set2 = {2, 4, 6, 8, 10}
# 交集
print(set1 & set2)                # {2, 4, 6}
print(set1.intersection(set2))    # {2, 4, 6}

# 并集
print(set1 | set2)         # {1, 2, 3, 4, 5, 6, 7, 8, 10}
print(set1.union(set2))    # {1, 2, 3, 4, 5, 6, 7, 8, 10}

# 差集
print(set1 - set2)              # {1, 3, 5, 7}
print(set1.difference(set2))    # {1, 3, 5, 7}

# 对称差,不算交集的剩下两个加起来
print(set1 ^ set2)                        # {1, 3, 5, 7, 8, 10}
print(set1.symmetric_difference(set2))    # {1, 3, 5, 7, 8, 10}
print((set1 | set2) - (set1 & set2))      # {1, 3, 5, 7, 8, 10}

类/对象

代码笔记

  • print 中 end 的用法,相当于替换\n换行
>>>print('ABC',end ='123')
>>>print('DEF')
ABC123DEF
  • 后续补充
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python 是一种易于学习又功能强大的编程语言。它提供了高效的高级数据结构,还有简单有效的面向对象编程。Python 优雅的语法和动态类型,以及解释型语言的本质,使它成为多数平台上写脚本和快速开发应用的理想语言Python 解释器及丰富的标准库以源码或机器码的形式提供,可以到 Python 官网 https://www.python.org/ 免费获取适用于各个主要系统平台的版本,并可自由地分发。这个网站还包含许多免费第三方 Python 模块、程序和工具以及附加文档的发布页面或链接。 Python 解释器易于扩展,可以使用 C 或 C++(或者其他可以通过 C 调用的语言)扩展新的功能和数据类型。Python 也可用于可定制化软件中的扩展程序语言。 这个教程非正式地介绍 Python 语言和系统的基本概念和功能。最好在阅读的时候准备一个 Python 解释器进行练习,不过所有的例子都是相互独立的,所以这个教程也可以离线阅读。 有关标准的对象和模块,参阅 Python 标准库。Python 语言参考 提供了更正式的语言参考。想要编写 C 或者 C++ 扩展可以参考 扩展和嵌入 Python 解释器 和 Python/C API 参考手册。也有不少书籍深入讲解Python 。 这个教程并没有完整包含每一个功能,甚至常用功能可能也没有全部涉及。这个教程只介绍 Python 中最值得注意的功能,也会让你体会到这个语言的风格特色。学习完这个教程,你将可以阅读和编写 Python 模块和程序,也可以开始学习更多的 Python 库模块,详见 Python 标准库。
python爬虫与项目实战,网络爬虫是一个自动提取网页的程序,它为搜索引擎从万维网上下载网页,是搜索引擎的重要组成。 随着网络的迅速发展,万维网成为大量信息的载体,如何有效地提取并利用这些信息成为一个巨大的挑战。搜索引擎(Search Engine),例如传统的通用搜索引擎AltaVista,Yahoo!和Google等,作为一个辅助人们检索信息的工具成为用户访问万维网的入口和指南。但是,这些通用性搜索引擎也存在着一定的局限性,如: (1)不同领域、不同背景的用户往往具有不同的检索目的和需求,通用搜索引擎所返回的结果包含大量用户不关心的网页。 (2)通用搜索引擎的目标是尽可能大的网络覆盖率,有限的搜索引擎服务器资源与无限的网络数据资源之间的矛盾将进一步加深。 (3)万维网数据形式的丰富和网络技术的不断发展,图片、数据库、音频、视频多媒体等不同数据大量出现,通用搜索引擎往往对这些信息含量密集且具有一定结构的数据无能为力,不能很好地发现和获取。 (4)通用搜索引擎大多提供基于关键字的检索,难以支持根据语义信息提出的查询。 网络爬虫 为了解决上述问题,定向抓取相关网页资源的聚焦爬虫应运而生。聚焦爬虫是一个自动下载网页的程序,它根据既定的抓取目标,有选择的访问万维网上的网页与相关的链接,获取所需要的信息。与通用爬虫(general purpose web crawler)不同,聚焦爬虫并不追求大的覆盖,而将目标定为抓取与某一特定主题内容相关的网页,为面向主题的用户查询准备数据资源。 传统爬虫从一个或若干初始网页的URL开始,获得初始网页上的URL,在抓取网页的过程中,不断从当前页面上抽取新的URL放入队列,直到满足系统的一定停止条件。聚焦爬虫的工作流程较为复杂,需要根据一定的网页分析算法过滤与主题无关的链接,保留有用的链接并将其放入等待抓取的URL队列。然后,它将根据一定的搜索策略从队列中选择下一步要抓取的网页URL,并重复上述过程,直到达到系统的某一条件时停止。另外,所有被爬虫抓取的网页将会被系统存贮,进行一定的分析、过滤,并建立索引,以便之后的查询和检索;对于聚焦爬虫来说,这一过程所得到的分析结果还可能对以后的抓取过程给出反馈和指导。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值