我一辈子都在写代码,但从来没有掌握编码的精髓。大部分情况下使用Visual Basic,因为我用VB最舒服。同时还略微了解一点其他语言(R、C、JavaScript、Applescript、Hypertext和1979年学习的BASIC)。几年前,我决定只用Python,以此来提高我的编码能力。在此过程中重复发明了许多轮子,但我并不介意,因为我享受解决问题的乐趣。同时有时能发现更有效、Python式的解决方案。时间长了以后,会有顿悟的时刻,意识到根本没必要用困难且冗长的方式处理问题。下面列出10条Python用法,如果我早点发现,也许能节省很多时间。

这里没有列表推导和lambda函数。虽然这两个用法都是Python式的,效率高也非常酷,但由于经常在StackOverflow或其他地方碰到,所以学Python的应该都知道这两个东西。同时也没有三元运算符、装饰器和生成器,因为我很少用到。

本文还有一个IPython notebook nbviewer版本。

1. 在Python 2中使用Python 3式的输出

Python 2与Python 3不兼容,这让我不知道该选择哪个版本的Python。最终我选择了Python 2,因为当时许多我需要用的库都与Python 3不兼容。

但实际上,日常使用中最大的版本差异是输出(print)和除法行为。现在我在Python 2的代码中都用import from future来导入Python 3的输出和除法。现在我用到的几乎所有库都支持Python 3,因此会很快迁移到Python 3中。

mynumber = 5

print "Python 2:"

print "The number is %d" % (mynumber)

print mynumber / 2,

print mynumber // 2

from __future__ import print_function

from __future__ import division

print('nPython 3:')

print("The number is {}".format(mynumber))

print(mynumber / 2, end=' ')

print(mynumber // 2)

Python 2:

The number is 5

2 2

Python 3:

The number is 5

2.5 2

对了,对于C系的那些更喜欢括号而不是缩进的开发者,这里还有一个彩蛋:

from __future__ import braces

File "", line 1

from __future__ import braces

SyntaxError: not a chance

2. enumerate(list)

很明显,迭代列表时,应该同时迭代其中的元素及其索引,但在很长一段时间内,我都尴尬的使用计数变量或切片。

mylist = ["It's", 'only', 'a', 'model']

for index, item in enumerate(mylist):

print(index, item)

0 It's

1 only

2 a

3 model

3. 链式比较操作符

由于我以前使用的是静态语言(在这些语言中该用法有二义性),从来没有将两个比较操作符放在一个表达式中。在许多语言中,4 > 3 > 2会返回False,因为4 > 3的结果是布尔值,而True > 2将得出False。

mynumber = 3

if 4 > mynumber > 2:

print("Chained comparison operators work! n" * 3)

Chained comparison operators work!

Chained comparison operators work!

Chained comparison operators work!

4. collections.Counter

Python的集合库看上去是最好的。在计算需要集合中元素的个数时,StackOverflow找到的答案是创建有序字典,但我坚持使用一个代码片段来创建字典,计算结果中元素出现的频率。直到有一天,我发现可以用collections.deque。

from collections import Counter

from random import randrange

import pprint

mycounter = Counter()

for i in range(100):

random_number = randrange(10)

mycounter[random_number] += 1

for i in range(10):

print(i, mycounter[i])

0 10

1 10

2 13

3 6

4 6

5 11

6 10

7 14

8 12

9 8

5. 字典推导

Python开发者的一个重要标志就是理解列表推导,但最终我发现字典推导也很有用,特别是在交换字典的键和值的时候。

my_phrase = ["No", "one", "expects", "the", "Spanish", "Inquisition"]

my_dict = {key: value for value, key in enumerate(my_phrase)}

print(my_dict)

reversed_dict = {value: key for key, value in my_dict.items()}

print(reversed_dict)

{'Inquisition': 5, 'No': 0, 'expects': 2, 'one': 1, 'Spanish': 4, 'the': 3}

{0: 'No', 1: 'one', 2: 'expects', 3: 'the', 4: 'Spanish', 5: 'Inquisition'}

6. 用subprocess执行shell命令

以前,我使用os库调用外部命令处理文件,而现在我可以在Python中以编码的方式执行诸如ffmpeg这样的复杂命令进行视频编辑。

(是的,我和我的客户都使用Windows,如果你们因此鄙视我,我会大方地接受!)

注意,用os库完成这个特定命令比用subprocess更好。我只想有一个大家都熟悉的命令。同时,一般来说,在subprocess中使用shell=True参数是非常糟糕的主意,在这里使用这个参数仅仅是为了能在一个IPython notebook单元中放置命令的输出。不要自己使用这个参数!

import subprocess

output = subprocess.check_output('dir', shell=True)

print(output)

Volume in drive C is OS

Volume Serial Number is [REDACTED]

Directory of C:UsersDavidDocuments[REDACTED]

2014-11-26 06:04 AM

2014-11-26 06:04 AM

2014-11-23 11:47 AM

2014-11-26 06:06 AM

2014-11-23 08:59 AM

2014-09-03 06:58 AM 19,450 colorbrewdict.py

2014-09-03 06:58 AM 92,175 imagecompare.ipynb

2014-11-23 08:41 AM

2014-09-03 06:58 AM 1,100 LICENSE

2014-09-03 06:58 AM 5,263 monty_monte.ipynb

2014-09-03 06:58 AM 31,082 pocket_tumblr_reddit_api.ipynb

2014-11-26 06:04 AM 3,211 README.md

2014-11-26 06:14 AM 19,898 top_10_python_idioms.ipynb

2014-09-03 06:58 AM 5,813 tree_convert_mega_to_gexf.ipynb

2014-09-03 06:58 AM 5,453 tree_convert_mega_to_json.ipynb

2014-09-03 06:58 AM 1,211 tree_convert_newick_to_json.py

2014-09-03 06:58 AM 55,970 weather_ML.ipynb

11 File(s) 240,626 bytes

6 Dir(s) 180,880,490,496 bytes free

7. 字典的.get()和.iteritems()方法

字典的get()方法可以设置默认值,当用get()查找的键不存在时,返回方法中的默认值参数是很有用的。与列表中的enumerate()相同,可以用键值元组迭代字典中的元素。

my_dict = {'name': 'Lancelot', 'quest': 'Holy Grail', 'favourite_color': 'blue'}

print(my_dict.get('airspeed velocity of an unladen swallow', 'African or European?n'))

for key, value in my_dict.iteritems():

print(key, value, sep=": ")

African or European?

quest: Holy Grail

name: Lancelot

favourite_color: blue

8. 用于交换元素的元组解包

在VB中,每当需要交换两个变量时,都要用要一个愚蠢的临时变量:c = a; a = b; b = c

a = 'Spam'

b = 'Eggs'

print(a, b)

a, b = b, a

print(a, b)

Spam Eggs

Eggs Spam

9. 内省工具Introspection tools

我知道dir()方法,我本以为help()方法和IPython中的?魔法命令是一样的,但help()的功能更强大。

my_dict = {'That': 'an ex-parrot!'}

help(my_dict)

Help on dict object:

class dict(object)

| dict() -> new empty dictionary

| dict(mapping) -> new dictionary initialized from a mapping object's

| (key, value) pairs

| dict(iterable) -> new dictionary initialized as if via:

| d = {}

| for k, v in iterable:

| d[k] = v

| dict(**kwargs) -> new dictionary initialized with the name=value pairs

| in the keyword argument list. For example: dict(one=1, two=2)

|

| Methods defined here:

|

| __cmp__(...)

| x.__cmp__(y) <==> cmp(x,y)

|

| __contains__(...)

| D.__contains__(k) -> True if D has a key k, else False

|

| __delitem__(...)

| x.__delitem__(y) <==> del x[y]

|

| __eq__(...)

| x.__eq__(y) <==> x==y

|

[TRUNCATED FOR SPACE]

|

| update(...)

| D.update([E, ]**F) -> None. Update D from dict/iterable E and F.

| If E present and has a .keys() method, does: for k in E: D[k] = E[k]

| If E present and lacks .keys() method, does: for (k, v) in E: D[k] = v

| In either case, this is followed by: for k in F: D[k] = F[k]

|

| values(...)

| D.values() -> list of D's values

|

| viewitems(...)

| D.viewitems() -> a set-like object providing a view on D's items

|

| viewkeys(...)

| D.viewkeys() -> a set-like object providing a view on D's keys

|

| viewvalues(...)

| D.viewvalues() -> an object providing a view on D's values

|

| ----------------------------------------------------------------------

| Data and other attributes defined here:

|

| __hash__ = None

|

| __new__ =

| T.__new__(S, ...) -> a new object with type S, a subtype of T

10. PEP-8兼容的字符串连接

PEP8是Python编码样式指南。撇开其他的不看,PEP8要求每行不能超过80个字符,超过的部分要换行并缩进。

可以通过反斜杠、带逗号“,”的圆括号“()”、或者额外的加号“+”来完成换行。但对于多行字符串,这些解决方案都不够优雅。Python有个多行字符串记号,即三个引号,但这样无法换行后保持缩进。

还有一个方法,那就是不带逗号的圆括号。我不知道为什么这种方式能工作,但能用就行。

my_long_text = ("We are no longer the knights who say Ni! "

"We are now the knights who say ekki-ekki-"

"ekki-p'tang-zoom-boing-z'nourrwringmm!")

print(my_long_text)

we are no longer the knights who say Ni! We are now the knights who say ekki-ekki-ekki-p'tang-zoom-boing-z'nourrwringmm!

python counter用法_10个易被忽视但应掌握的Python基本用法相关推荐

  1. python基本使用-10个易被忽视但应掌握的Python基本用法

    我一辈子都在写代码,但从来没有掌握编码的精髓.大部分情况下使用Visual Basic,因为我用VB最舒服.同时还略微了解一点其他语言(R.C.JavaScript.Applescript.Hyper ...

  2. python 安卓平板_10 个可以在平板电脑上使用的 Python 编辑器 ,让编程更贴近生活!...

    本文介绍 10 个可在 iOS 或 Android 平板电脑上的 Python 编程环境.Python 开发者可通过这些工具实现随时随地编码,蛋疼抑或爽极? 1.Pythonista Python 声 ...

  3. python和R数据类型查看、赋值、列表、for循环、函数用法对比示例

    python和R数据类型查看.赋值.列表.for循环.函数用法对比示例 很多工程师可能刚开始的时候只熟悉python或者R其中的一个进行数据科学相关的任务. 那么如果我们对比这学习可以快速了解语言设计 ...

  4. python counter函数定义_分享几个自己常用的Python高级函数

    哈喽大家好我是蚂蚁,今天给大家分享几个我自己常用的Python相对高级点的函数,这些函数在特定的场景下能节省大量的代码. 简单列举一下我想要介绍的几个函数: counter:计数器 defaultdi ...

  5. python 装饰器 参数-python函数装饰器之带参数的函数和带参数的装饰器用法示例...

    本文实例讲述了python函数装饰器之带参数的函数和带参数的装饰器用法.分享给大家供大家参考,具体如下: 1. 函数带多个参数 # 普通的装饰器, 打印函数的运行时间 def decrator(fun ...

  6. python装饰器函数-python函数装饰器之带参数的函数和带参数的装饰器用法示例

    本文实例讲述了python函数装饰器之带参数的函数和带参数的装饰器用法.分享给大家供大家参考,具体如下: 1. 函数带多个参数 # 普通的装饰器, 打印函数的运行时间 def decrator(fun ...

  7. 几点易被忽视的网络软故障排查

    几年的以太网络维护中,遇到了很多令人头疼的故障,但排除后,却又觉得自己很笨.这就是易被忽视的网络软故障而导致的.初次面对这类故障时,往往使人会束手无策,多次往复排查而无结果,当问题迎刃而解时,却又显得 ...

  8. Python语言学习之字母S开头函数使用集锦:set/sys/super用法之详细攻略

    Python语言学习之字母S开头函数使用集锦:set/sys/super用法之详细攻略 set用法 set顾名思义是集合,里面不能包含重复的元素,接收一个list作为参数 list1=[1,2,3,4 ...

  9. python多个strip_python 格式化多个Python3中strip()、lstrip()、rstrip()用法详解

    Python中有三个去除头尾字符.空白符的函数,它们依次为: strip: 用来去除头尾字符.空白符(包括n.r.t.' ',即:换行.回车.制表符.空格) lstrip:用来去除开头字符.空白符(包 ...

最新文章

  1. HashMap内部结构深入剖析
  2. JavaScript——this、constructor、prototype
  3. 储存卡怎么格式化为fat32_电脑复制文件到U盘提示文件容量太大该怎么办?
  4. .NET : 动态生成工作流定义文件并且进行编译
  5. Linux基础知识之挂载详解(mount,umount及开机自动挂载)
  6. Fail at Scale
  7. echarts树图节点垂直间距_铝模板的安装、拆除、节点、禁止做法详解
  8. ERC20代币合约详解,附实现代码
  9. SQL 错误: ORA-12910
  10. C/C++常见面试题整理
  11. MAC OS(U盘启动教程)
  12. 交易记录表设计注意点
  13. 手机社会化分享到qq好友、qq空间、微信、微信朋友圈、微博等(区分浏览器)
  14. 用技术赋能城市管理,景联文科技提供城市治理多场景数据采集服务!
  15. win7删除计算机 网络打印机驱动程序,Windows 7、8 系统下手动删除打印机驱动程序的方法...
  16. web audio api 实现音频播放
  17. 10大关键词解读中国互联网五年间创新飞跃在哪里
  18. 实战 .Net 数据访问层 - 19
  19. C语言程序设计博客作业07
  20. python dfs

热门文章

  1. 告别并不遥远的儿时,抬眼期待未来
  2. java计算程序执行时间_java计算程序执行所用时间例子
  3. Android笔记 android 7.0 动态申请权限
  4. Android笔记 fragment的生命周期
  5. LeetCode-567:字符串的排列
  6. CenterNet+ deepsort实现多目标跟踪
  7. form表单 vue 拖拽_vue实现可视化可拖放的自定义表单(代码示例)
  8. 【前端基础知识】chrome安装React Devtools
  9. 在JSP页面中获取系统当前日期时间
  10. Vue2.0 探索之路——生命周期和钩子函数