20年资深程序员的Python“秘籍”,教你成为其中的“武林高手”

简介:   我列出的这些有用的Python代码片段,为我节省了大量的时间,并且我希望他们也能为你节省一些时间。大多数的这些片段出自寻找解决方案,查找博客和StackOverflow解决类似问题的答案。下面所有的代码片段已经在Python 3中测试。  在Python中调用一个外部命令  有时你需要通过shell或命令提示符调用一个外部命令,这在Python中通过使用subprocess模块很容易实现。

  我列出的这些有用的Python代码片段,为我节省了大量的时间,并且我希望他们也能为你节省一些时间。大多数的这些片段出自寻找解决方案,查找博客和StackOverflow解决类似问题的答案。下面所有的代码片段已经在Python 3中测试。

  在Python中调用一个外部命令

  有时你需要通过shell或命令提示符调用一个外部命令,这在Python中通过使用subprocess模块很容易实现。

  只需要运行一条命令:

  import subprocesssubprocess.call(['mkdir', 'empty_folder'])

  如果想运行一条命令并输出得到的结果:

  import subprocessoutput=subprocess.check_output(['ls', '-l'])

  要说明的是上面的调用是阻塞的。

  如果运行shell中内置的命令,如cd或者dir,需要指定标记shell=True:

  import subprocessoutput=subprocess.call(['cd', '/'], shell=True)

  对于更高级的用例,可以使用 Popen constructor。

  Python 3.5引进了一个新的run函数,它的行为与call和check_output很相似。如果你使用的是3.5版本或更高版本,看一看run的文档,里面有一些有用的例子。否则,如果你使用的是Python 3.5以前的版本或者你想保持向后兼容性,上面的call和check_output代码片段是你最安全和最简单的选择。

  美观打印

  开发时使用pprint模块替代标准的print 函数,可以让shell输出的信息更具可读性。这使得输出到shell上的字典和嵌套对象更易读。

  import pprint as ppanimals=[{'animal': 'dog', 'legs': 4, 'breeds': ['Border Collie', 'Pit Bull', 'Huskie']}, {'animal': 'cat', 'legs': 4, 'breeds': ['Siamese', 'Persian', 'Sphynx']}]pp.pprint(animals, width=1)

  width参数指定一行上最大的字符数。设置width为1确保字典打印在单独的行。

  按属性进行数据分组

  假设你查询一个数据库,并得到如下数据:

  data=[{'animal': 'dog', 'name': 'Roxie', 'age': 5},{'animal': 'dog', 'name': 'Zeus', 'age': 6},{'animal': 'dog', 'name': 'Spike', 'age': 9},{'animal': 'dog', 'name': 'Scooby', 'age': 7},{'animal': 'cat', 'name': 'Fluffy', 'age': 3},{'animal': 'cat', 'name': 'Oreo', 'age': 5},{'animal': 'cat', 'name': 'Bella', 'age': 4}]

  通过动物类型分组得到一个狗的列表和一个猫的列表。幸好,Python的itertools有一个groupby函数可以让你很轻松的完成这些。

  from itertools import groupbydata=[{'animal': 'dog', 'name': 'Roxie', 'age': 5},{'animal': 'dog', 'name': 'Zeus', 'age': 6},{'animal': 'dog', 'name': 'Spike', 'age': 9},{'animal': 'dog', 'name': 'Scooby', 'age': 7},{'animal': 'cat', 'name': 'Fluffy', 'age': 3},{'animal': 'cat', 'name': 'Oreo', 'age': 5},{'animal': 'cat', 'name': 'Bella', 'age': 4}]for key, group in groupby(data, lambda x: x['animal']):for thing in group:print(thing['name'] + " is a " + key)

  得到的输出是:

  Roxie is a dogZeus is a dogSpike is a dogScooby is a dogFluffy is a catOreo is a catBella is a cat

  groupby()有2个参数:1、我们想要分组的数据,它在本例中是一个字典。2、分组函数:lambda x: x['animal']告诉groupby函数每个字典按动物的类型分组

  现在通过列表推导式可以很容易地构建一个狗的列表和一个猫的列表:

  from itertools import groupbyimport pprint as ppdata=[{'animal': 'dog', 'name': 'Roxie', 'age': 5},{'animal': 'dog', 'name': 'Zeus', 'age': 6},{'animal': 'dog', 'name': 'Spike', 'age': 9},{'animal': 'dog', 'name': 'Scooby', 'age': 7},{'animal': 'cat', 'name': 'Fluffy', 'age': 3},{'animal': 'cat', 'name': 'Oreo', 'age': 5},{'animal': 'cat', 'name': 'Bella', 'age': 4}]grouped_data={}for key, group in groupby(data, lambda x: x['animal']):grouped_data[key]=[thing['name'] for thing in group]pp.pprint(grouped_data)

  最后得到一个按动物类型分组的输出:

  {'cat': ['Fluffy','Oreo','Bella'],'dog': ['Roxie','Zeus','Spike','Scooby']}

  StackOverflow上这个问题的答案非常有帮助,当我试图找出如何以最Pythonic的方式分组数据时,这篇文章节省了我很多时间。

  删除列表中的重复元素

  Python中用一行代码快速简单的删除一个列表中的重复元素(不维持顺序):

  x=[1, 8, 4, 5, 5, 5, 8, 1, 8]list(set(x))

  这个方法利用了set是一个不同的对象的文凭集合这一事实。然而,set不维持顺序,

  因此如果你在乎对象的顺序,使用下面的技术:

  from collections import OrderedDictx=[1, 8, 4, 5, 5, 5, 8, 1, 8]list(OrderedDict.fromkeys(x))

  访问Python的For循环的索引

  对于许多人来说这可能是常识,但这也是经常问的。Python的内置enumerate 函数提供索引和值的访问如下:

  x=[1, 8, 4, 5, 5, 5, 8, 1, 8]for index, value in enumerate(x):print(index, value)

  通过指定enumerate函数的start参数改变起始索引:

  x=[1, 8, 4, 5, 5, 5, 8, 1, 8]for index, value in enumerate(x, start=1):print(index, value)

  现在该索引从1到9而不是0到8

  并行遍历2个集合

  使用内置zip函数同时遍历2个列表,字典,等。下面是使用zip函数同时遍历2个列表的例子:

  a=[1, 2, 3]b=[4, 5, 6]for (a_val, b_val) in zip(a, b):print(a_val, b_val)

  将输出:

  1 42 53 6

  创建对象的Copy

  Python中可以使用通用的copy函数复制一个对象。浅拷贝是通过使用copy.copy调用的:

  import copynew_list=copy.copy(old_list)

  深拷贝:

  import copynew_list=copy.deepcopy(old_list)

  这个StackOverflow问题对于复制一个列表的各种方法给出了很好的解释。如果你不熟悉浅拷贝和深拷贝之间的差异看一看这个解释。

  浮点除法

  通过将分子或分母转换为float类型,可以确保浮点除法:

  answer=a/float(b)

  字符串和日期相互转换

  一个常见的任务是将一个字符串转换为一个datetime对象。使用strptime 函数这将很容易做到:

  from datetime import datetimedate_obj=datetime.strptime('May 29 2022 2:45PM', '%B %d %Y %I:%M%p')

  它的逆操作是转换一个datetime对象为一个格式化的字符串,对datetime对象使用strftime函数:

  from datetime import datetimedate_obj=datetime.now()date_string=date_obj.strftime('%B %d %Y %I:%M%p')

  有关格式化代码的列表和他们的用途,查看官方文档

  解析JSON文件并写一个对象到JSON文件中

  使用load函数可以解析JSON文件并构建一个Python对象。假定有一个叫做data.json的文件包括以下数据:

  {"dog": {"lives": 1,"breeds": ["Border Collie","Pit Bull","Huskie"]},"cat": {"lives": 9,"breeds": ["Siamese","Persian","Sphynx"]}}import jsonwith open('data.json') as input_file:data=json.load(input_file)

  现在data是一个对象,你可以操作它像任何Python对象一样:

  print(data'cat')output: 9

  可以使用dump函数,将Python中的字典写入JSON文件中:

  import jsondata={'dog': {'legs': 4, 'breeds': ['Border Collie', 'Pit Bull', 'Huskie']}, 'cat': {'legs': 4, 'breeds': ['Siamese', 'Persian', 'Sphynx']}}with open('data.json', 'w') as output_file:json.dump(data, output_file, indent=4)

  缩进参数美观打印JSON字符串以便输出更容易阅读。在这种情况下,我们指定缩进4个空格。

目录
相关文章
|
4月前
|
算法 程序员 Python
程序员必看!Python复杂度分析全攻略,让你的算法设计既快又省内存!
在编程领域,Python以简洁的语法和强大的库支持成为众多程序员的首选语言。然而,性能优化仍是挑战。本文将带你深入了解Python算法的复杂度分析,从时间与空间复杂度入手,分享四大最佳实践:选择合适算法、优化实现、利用Python特性减少空间消耗及定期评估调整,助你写出高效且节省内存的代码,轻松应对各种编程挑战。
87 1
|
5月前
|
设计模式 JSON 程序员
豆瓣评分9.4!Python程序员必读的《流畅的Python》,放这里了!
Python 官方教程的开头是这样写的:“Python 是一门既容易上手又强大的编程语言。””这句话本身并无大碍,但需要注意的是,正因为它既好学又好用,所以很多Python程序员只用到了其强大功能的一小部分,只需要几个小时,经验丰富的程序员就能学会用 Python 写出实用的程序。 然而随着这最初高产的几个小时变成数周甚至数月,在那些先入为主的编程语言的影响下,开发者们会慢慢地写出带着“口音”的 Python 代码。即便 Python 是你的初恋,也难逃此命运。因为在学校里,亦或是那些入门书上,教授者往往会有意避免只跟语言本身相关的特性。
|
5月前
|
设计模式 JSON 程序员
豆瓣评分9.4!Python程序员必读的《流畅的Python》,放这里了!
Python 官方教程的开头是这样写的:“Python 是一门既容易上手又强大的编程语言。””这句话本身并无大碍,但需要注意的是,正因为它既好学又好用,所以很多Python程序员只用到了其强大功能的一小部分,只需要几个小时,经验丰富的程序员就能学会用 Python 写出实用的程序。 然而随着这最初高产的几个小时变成数周甚至数月,在那些先入为主的编程语言的影响下,开发者们会慢慢地写出带着“口音”的 Python 代码。即便 Python 是你的初恋,也难逃此命运。因为在学校里,亦或是那些入门书上,教授者往往会有意避免只跟语言本身相关的特性。
|
5月前
|
程序员 Python
[oeasy]python0028_女性程序员_Eniac_girls_bug_Grace
回顾上次内容,我们了解到 `.py` 文件中的代码是按顺序一行行被解释执行的,可以使用 `pdb3 hello.py` 来调试程序。此外,我们探讨了“bug”这一术语的由来,它最早是在 1947 年由 Grace Murray Hopper 发现的一只真正的飞蛾所引起的计算机故障,从此“debugging”成了查找并修复程序错误的过程。早期的程序员大多为女性,因为她们通常更加细心且有耐心,这些特质对于检查错综复杂的线路和编程工作至关重要。编程与编织有着相似之处,都需要细致和有条理的操作。最后,我们认识到 bug 的存在是程序员工作的基础,没有 bug 就不需要程序员去修正它们。
51 3
|
5月前
|
存储 JSON 程序员
Python文件操作与数据持久化:强大功能简化存储管理,助力程序员高效实现业务逻辑
【8月更文挑战第6天】数据是现代计算机程序的核心,但其存储与管理常常构成开发挑战。Python凭借其强大的文件操作与数据持久化机制,显著提升了编程效率。Python的文件处理简单直观,通过内置`open`函数即可轻松实现文本或二进制文件的读写。例如,仅需几行代码就能完成文本写入。此外,Python支持多种数据持久化方案,如文本文件、CSV、JSON及数据库操作。利用内置`json`模块,可以便捷地进行JSON数据的序列化与反序列化,实现数据的有效存储与检索。这些特性使得Python成为数据管理和存储的理想选择,让开发者能够更加专注于业务逻辑的实现。
53 0
|
6月前
|
监控 程序员 持续交付
`pylint`是一个高度可配置的Python代码分析工具,它可以帮助程序员查找代码中的错误、样式问题、可能的bug以及不符合编码标准的部分。
`pylint`是一个高度可配置的Python代码分析工具,它可以帮助程序员查找代码中的错误、样式问题、可能的bug以及不符合编码标准的部分。
|
Java 程序员 区块链
程序员数学基础【五、math库常用函数】(Python版本)(五)
程序员数学基础【五、math库常用函数】(Python版本)(五)
172 0
程序员数学基础【五、math库常用函数】(Python版本)(五)
|
程序员 Python
程序员数学基础【五、math库常用函数】(Python版本)(四)
程序员数学基础【五、math库常用函数】(Python版本)(四)
141 0
程序员数学基础【五、math库常用函数】(Python版本)(四)
|
程序员 Python
程序员数学基础【五、math库常用函数】(Python版本)(三)
程序员数学基础【五、math库常用函数】(Python版本)(三)
242 0
程序员数学基础【五、math库常用函数】(Python版本)(三)