(1)缩进错误 演示代码: >>> if 5>3: print('5>3') SyntaxError: expected an indented block >>> for i in range(5): print(i) SyntaxError: expected an indented block 错误原因分析与解决方案: Python代码对缩进的要求非常严格,代码缩进层级决定了代码的所属关系。Python初学者最容易遇到的错误应该就是缩进错误,遇到这样的错误时,要仔细检查代码中的缩进是否与预定义的功能逻
列表 列表是 Python 的主力数据类型。当提到 “ 列表 ” 时,您脑海中可 能会闪现“ 必须进一步声明大小的数组,只能包含同一类对象 “ 等想法。千万别这么想。列表比那要酷得多。 ☞ Python 中的列表类似 Perl 5 中的数组。在 Perl 5 中,存储数组的变量总是以字符 @ 开头;在 Python 中,变量可随意命名,Python 仅在内部对数据类型 进行跟踪。 ☞ Python 中的列表更像 Java 中的数组(尽管可以
列表用【】包含,内有数据对象,每个数据对象以‘,’分隔,每个数据对象称为元素
出现"object is not subscriptable"错误的常见原因之一是,你尝试对一个非可迭代对象进行下标操作。以字典为例,当你使用字典的键来访问对应的值时,需要使用字典的下标操作符[]。而如果你尝试对一个非字典对象(如整数、字符串等)进行下标操作,就会出现该错误。 另一个可能的原因是,你尝试对一个可迭代对象的属性进行下标操作。例如,对一个自定义类的实例进行下标操作的时候,需要确保该类实现了__getitem__()方法来支持下标访问。
在使用NumPy进行数组计算时,有时会遇到"AttributeError: 'NoneType' object has no attribute 'array_interface'"的错误。这个错误通常是由于数组对象为None引起的。在本篇文章中,我们将介绍这个错误的原因,并提供解决方法。
之前所写这篇文章是因为最近在帮助团队招聘、面试的过程中,看到很多人的简历上都提及自己擅长功能测试,擅长Python以及各类的自动化测试框架、测试工具,而当我提问用过哪些方法进行测试用例设计时,大多数同学的回答都是等价类划分、边界值,其他的甚至都没听说过;当我问到Python有哪些常见的数据类型以及它们有哪些常用方法、哪些是可变类型等这些基础的问题时,很多人都答不上来。
正则表达式为高级的文本模式匹配、抽取、与/或文本形式的搜索和替换功能提供了基础。通过标准库中的re模块来支持正则表达式。 常见的正则表达式符号和特殊字符 表示法 描述 正则表达式示例 符号 re1|re2 匹配正则表达式re1或者re2 foo|bat . 匹配任何字符(除了\n之外) b.b ^ 匹配字符串的起始部分 ^Dear $ 匹配字符串的终止部分 /bin/*sh$ * 匹配0次或者多次前面出现的正则表达式 [A-Za-z0-9]* + 匹配1次或者多次前
学习Python这么久了,还没尝试写过实战项目,今天和大家分享一个用Python实现的文件搜索的一个小项目。
python之禅中有这样一句:simple is better than complex。翻译成中文我想就是“大道至简、大巧不工”。
Guido van Rossum 认为使用缩进进行分组非常优雅,并且大大提高了普通 Python 程序的清晰度。大多数人在一段时间后就学会并喜欢上这个功能。
https://docs.python.org/zh-cn/3.7/faq/design.html
本文选自 Python 的官方文档。它列举了 27 个设计及历史的问题,其中有些问题我曾经分享过,例如为什么使用显式的 self、浮点数的问题、len(x) 而非 x.len() 等等。大部分的回答很简略精要,适合在空闲之余翻阅。建议你先收藏起来,随时查看,温故知新。
看到豌豆花下猫在 Python 猫公众号推的这篇文章,虽说是从文档里节选的,但是对深入学习Python很有价值,也推荐给大家。
可以直接使用list()创建一个新的列表,或者,使用list()将一个对象转换成列表。
本文主要记录Python的基础知识,这同样是每一个Python用户所要走过的必经之路。任何一段复杂的Python代码,归根结底都是由最简单的元素构成。只有夯实基础,方能轻松自如。
本文将列举了一些在面试当中经常被提及的经典Python考问题并且提供了答案,献给那些已经毕业的应届大学生们以及其他求职者们
“为什么治安警察抓人并刑讯逼供来获取他们的信息?硬盘对酷刑毫无抵抗力。你需要给硬盘一个抵抗的方法。这就是密码学。”
算法分析 (Analysis of algorithms) 是计算机科学的一个分支, 着重研究算法的性能, 特别是它们的运行时间和资源开销。见 http://en.wikipedia.org/wiki/Analysis_ofalgorithms 。
文章目录 1、列表的查询 2、列表的增加 3、列表中的删除 4、列表的修改 5、列表遍历 6、列表的嵌套 7、元组的定义 8、元组的相关操作 9、字典的定义 10、字典的增加 11、字典的删除 12、字典的修改 13、字典的查询 14、字典的遍历 15、集合的定义 16、集合的相关操作 1、列表的查询 index:从左至右查询元素在列表中所处的位置,如果查询到该元素返回其第一次出现所在位置的正向下标,如果不存在则报错 count:查询指定元素在列表中出现的次数 in:查询指定元素是否在列表中 not in:
元组中的不可变对象是不能被修改的哟.如果里面是列表等可变数据类型的话,可以进行修改.
1、字典是无序的,它不能通过偏移来存取,只能通过键来存取。可以嵌套,字典 = {'key':value} key:类似我们现实的钥匙,而value则是锁。一个钥匙开一个锁
您还可以通过在花括号 {carname} 中输入名称来使用命名索引,但是在传递参数值 txt.format(carname = “Ford”) 时,必须使用名称:
1.NoneType: The Null object--空对象 2.Numerics(数值): int-整数, long-长整数, float-浮点数, complex-复数, and bool--布尔值 (The subclass of int with True or False value) 3.Sequences(序列): str-字符串, list-列表, tuple-元组, and range-范围 4.Mappings(映射): dict-字典 5.Sets(集合): set-可变集合 and frozenset-不可变集合
注意:在python3中input获取键盘输入的数据,都以字符串的方式进行保存,即使输入的是数字。
一、字典介绍 字典(dictionary)是除列表意外python之中最灵活的内置数据结构类型。列表是有序的对象结合,字典是无序的对象集合。两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。 1、字典的主要属性 *通过键而不是偏移量来读取 字典有时称为关联数组或者哈希表。它们通过键将一系列值联系起来,这样就可以使用键从字典中取出一项。如果列表一样可以使用索引操作从字典中获取内容。 *任意对象的无序集合 与列表不同,保存在字典中的项并没有特定的顺序。实际上,Python将各项从左到右随机排序,以便快速查找。键提供了字典中项的象征性位置(而非物理性的)。 *可变,异构,任意嵌套 与列表相似,字典可以在原处增长或是缩短(无需生成一份拷贝),可以包含任何类型的对象,支持任意深度的嵌套,可以包含列表和其他字典等。 *属于可变映射类型 通过给索引赋值,字典可以在原处修改。但不支持用于字符串和列表中的序列操作。因为字典是无序集合,根据固定顺序进行操作是行不通的(例如合并和分片操作)。字典是唯一内置的映射类型(键映射到值得对象)。 *对象引用表(哈希表) 如果说列表是支持位置读取对象的引用数组,那么字典就是支持键读取无序对象的引用表。从本质上讲,字典是作为哈希表(支持快速检索的数据结构)来实现的。一开始很小,并根据要求而增长。此外,Python采用最优化的哈希算法来寻找键,因此搜索是很快速的。和列表一样字典存储的是对象引用。 2、常见的字典操作 可以查看库手册或者运行dir(dict)或者help(dict),类型名为dict。当写成常量表达式时,字典以一系列"键:值(key:value)”对形式写出的,用逗号隔开,用大括号括起来。可以和列表和元组嵌套 操作 解释 D1={} 空字典 D={'one':1} 增加数据 D1[key]='class' 增加数据:已经存在就是修改,没有存在就是增加数据 D2={'name':'diege','age':18} 两项目字典 D3={'name':{'first':'diege','last':'wang'},'age':18} 嵌套 D2['name'] 以键进行索引计算 D3['name']['last'] 字典嵌套字典的键索引 D['three'][0] 字典嵌套列表的键索引 D['six'][1] 字典嵌套元组的键索引 D2.has_key('name') 方法:判断字典是否有name键 D2.keys() 方法:键列表 list(D) 获取D这个字典的的KEY的 MS按字典顺序排序成一个列表 D2.values() 方法:值列表 'name' in D2 方法:成员测试:注意使用key来测试 D2.copy() 方法:拷贝 D2.get(key,deault) 方法:默认 如果key存在就返回key的value,如果不存在就设置key的value为default。但是没有改变原对象的数据 D2.update(D1) 方法:合并。D1合并到D2,D1没有变化,D2变化。注意和字符串,列表好的合并操作”+“不同 D2.pop('age') 方法:删除 根据key删除,并返回删除的value len(D2) 方法:求长(存储元素的数目) D1[key]='class' 方法:增加:已经存在的数据就是修改,没有存在就是增加数据 D4=dict(name='diege',age=18) 其他构造技术 D5=dict.fromkeys(['a','b']) 其他构造技术 dict.fromkeys 可以从一个列表读取字典的key 值默认为空,可指定初始值.两个参数一个是KEY列表,一个初始值 >>> D4 {'a': None, 'b': None} >>> D5=dict.fromkeys(['a
在 Python 中,数据属性和方法统称为属性。方法是可调用的属性。动态属性呈现与数据属性相同的接口——即,obj.attr——但是根据需要计算。这遵循 Bertrand Meyer 的统一访问原则:
这只是一些常见的错误异常,实际上Python还有很多其他的异常类型。在编写代码时,应该注意捕获和处理这些异常,以便更好地调试和处理错误。
Q:如何查看内置函数与方法? A:dir(builtins) 或者 dir(模块),以help查询具体方法的说明
在字典中,存储的是[键, 值]对,其中键名是用来查询特定元素的。字典和集合很相似,集合以[值, 值]的形式存储元素,字典则是以[键, 值]的形式来存储元素。字典也称作映射、符号表或关联数组。
本着这种精神,这是我的python面试/工作准备问题和答案。大多数数据科学家编写了大量代码,因此这对科学家和工程师均适用。
Python提供了5中内置的序列类型:bytearray、bytes、list、str与tuple,序列类型支持成员关系操作符(in)、大小计算函数(len())、分片([]),并且是可可迭代的。
python之所以如此受欢迎的原因之一是因为它可读性和表现力强。 人们经常开玩笑说Python是“可执行伪代码”。但是,当你可以编写这样的代码时,很难用其他方式反驳:
当谈到实践项目时,没有一个正确的程序。只要你的程序执行了项目所要求的,你就可以认为它是正确的。然而,如果你想看已完成项目的例子,可以在的“下载书中使用的文件”链接中找到。
Python 处理大数据集可以借助 Python 内置数据结构:列表、元组、字典 、 集合等,但是一般要和 pandas 和 Numpy 等库结合起来使用。
上面的例子中对应的值可以是任何数据类型,如:字符串、布尔值、列表、元组、集合或字典。
redis(remote dictionary server 远程字典服务器)是一个开源高性能的键值对数据库,通过提供多种键值数据类型来适应不同场景下的存储需求,并借助高层次的接口来胜任缓存、队列等角色。
元组是一个固定长度,不可改变的Python序列对象,创建元组的最简单方式,是用逗号分隔一列值。当用复杂的表达式定义元组,最好将值放到圆括号内。
(一) 简单说明 字典是Python的内置数据结构,将数据与键关联(例如:姓名:张三,姓名是键,张三就是数据)。例如:下面这个就是一个字典 {'姓名': '张三', '出生日期': '2899-08-12', '成绩': ['3.21', '3.10', '3.01']} 创建字典、添加数据、访问字典数据的方式如下: d = {} #直接用{}创建字典 f = dict() #通过工厂函数dict()创建字典 #通过下面的方式添加数据 d['姓名'] = '张三' d['出生日期'] =
#字典的添加、删除、修改操作 dict = {"a" : "apple", "b" : "banana", "g" : "grape", "o" : "orange"} dict["w"] = "watermelon" del(dict["a"]) dict["g"] = "grapefruit" print dict.pop("b") print dict dict.clear() print dict #字典的遍历 dict = {"a" : "apple", "b" : "banana", "g" : "grape", "o" : "orange"} for k in dict: print "dict[%s] =" % k,dict[k] #字典items()的使用 dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"} #每个元素是一个key和value组成的元组,以列表的方式输出 print dict.items() #调用items()实现字典的遍历 dict = {"a" : "apple", "b" : "banana", "g" : "grape", "o" : "orange"} for (k, v) in dict.items(): print "dict[%s] =" % k, v #调用iteritems()实现字典的遍历 dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"} print dict.iteritems() for k, v in dict.iteritems(): print "dict[%s] =" % k, v for (k, v) in zip(dict.iterkeys(), dict.itervalues()): print "dict[%s] =" % k, v #使用列表、字典作为字典的值 dict = {"a" : ("apple",), "bo" : {"b" : "banana", "o" : "orange"}, "g" : ["grape","grapefruit"]} print dict["a"] print dict["a"][0] print dict["bo"] print dict["bo"]["o"] print dict["g"] print dict["g"][1] dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"} #输出key的列表 print dict.keys() #输出value的列表 print dict.values() #每个元素是一个key和value组成的元组,以列表的方式输出 print dict.items() dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"} it = dict.iteritems() print it #字典中元素的获取方法 dict = {"a" : "apple", "b" : "banana", "c" : "grape", "d" : "orange"} print dict print dict.get("c", "apple") print dict.get("e", "apple") #get()的等价语句 D = {"key1" : "value1", "key2" : "value2"} if "key1" in D: print D["key1"] else: print "None" #字典的更新 dict = {"a" : "apple", "b" : "banana"} print dict dict2 = {"c" : "grape", "d" : "orange"} dict.update(dict2) print dict #udpate()的等价语句 D = {"key1" : "value1", "key2" : "value2"} E = {"key3" : "value3", "key4" : "value4"} for k in E: D[k] = E[k] print D #字典E中含有字典D中的key D = {"key1" : "value1", "key2" : "value2"} E = {"key2" : "value3", "key4" : "value4"} for k in E: D[k] = E[k]
例如,您可能有一个充满客户记录的电子表格,并希望根据每个客户的年龄和位置信息向他们发送不同的套用信函。商业软件可能无法为你做到这一点;幸运的是,您可以编写自己的程序来发送这些电子邮件,从而节省大量复制和粘贴表单电子邮件的时间。
CSV 代表“逗号分隔值”,CSV 文件是存储为纯文本文件的简化电子表格。Python 的csv模块使得解析 CSV 文件变得很容易。
原文:https://realpython.com/python-traceback/
使用python难免会出现各种各样的报错,以下是Python常见的报错以及解决方法(持续更新),快进入收藏吃灰吧
可对列表执行所有的标准序列操作,如索引、切片、拼接和相乘,但列表的有趣之处在于它不同于元组 是可以修改的。
insert(index, object) 在指定位置index前插入元素object
领取专属 10元无门槛券
手把手带您无忧上云