Python_编程特色

简介: 目录目录前言软件环境列表推导式字典的默认值forelse语句交换两个变量的值链式比较真值测试序列类型元素反转连接字符串和列表内置算术函数利用zip来创建键值对最后前言Python有着许多非常有意思的有别于别的高级语言的语法和处理方式,这些特别的变成技巧能够实现更少的代码量,更清晰的语法结构和更高的效率。

目录

前言

Python有着许多非常有意思的有别于别的高级语言的语法和处理方式,这些特别的变成技巧能够实现更少的代码量,更清晰的语法结构和更高的效率。

软件环境

  • 系统
    • UbuntuKylin 14.04
  • 软件
    • Python 2.7.3
    • IPython 4.0.0

列表推导式

列表推导式是一种轻量级的循环,是一种利用列表爱创建新的列表的方法。
基本语法格式

[expr for variable in listName]

Example:

In [18]: [x**2 for x in range(10)]
Out[18]: [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

上面例子中使用 List[0,1,2,..,9]和列表推导式生成了一个新的List[0,1,4,..,81],这还只是一个最基本的用法。
获取被一个数整除的数

In [20]: [x for x in range(100) if x %5 == 0]
Out[20]: [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95]

在推导式中可以使用if判断语句,相当于下面的语句块:

In [21]: newList = []

In [22]: for x in range(100):
   ....:     if x % 5 == 0:
   ....:         newList.append(x)
   ....:         

In [23]: newList
Out[23]: [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95]

相比较,列表推导式能够更加简洁的实现同一样的功能。
求素数
素数:即质数,简单来说就是不能被(2~N-1)之中任何一个整数整除的数N。其实N只需不被(2~N/2)之间的任何一个整数整除即可为素数,甚至可以将范围缩小到(2~sqrt(N)),以此来提高效率,当然处理的方法会需要改变。
下面是一个使用列表扩展式实现的例子:

[x for x in range(2,100) if not [y for y in range(2,int(x/2+1)) if x % y == 0]]

等效于:

primes = []
for x in range(2,100):          #1不是素数
    li = []                     #临时的List对象,只在for语句块中有效
    for y in range(2,x/2+1):    #因为在range()中,所以要+1补足
        if x % y == 0:
            li.append(x)
    if not li:                  #如果临时的li中为空,表示N为素数
        primes.append(x)
print primes

当li=[]时,表示N在(2~x/2+1)范围内没有被任何一个数整除,即N为素数,append到primes中。
再介绍一种写法:

noprimes = []
for i in range(2,8):
    for j in range(i*2,100,i):
        noprimes.append(j)
set(noprimes)
primes = []
for x in range(2,100):
    if x not in noprimes:
        primes.append(x)
print primes

这种方法利用了反推的思路,先通过[2~7]的倍数来找出noprimes,在判断N是否在noprimes中。若不在即N为素数。
扩展式的写法:

noprimes = set(j for i in range(2,8) for j in range(i*2, 100,i))
primes = [x for x in range(2,100) if x not in noprimes]

可以看出扩展式并不仅是List的专属,序列类型(Tuple、dictionary)和set集合类型都可以使用扩展式。而且如上面的例子,因为我们要频繁的去确定一个值是否存在,且元素是唯一的,所以可以选择set扩展式(set集合能更快的查找属性参数),来提高运行速度。所以,根据具体条件,充分的利用数据结构的特性来选择一个合适的扩展式类型可以有效的提高程序执行效率。
嵌套列表降维

In [143]: nestLi = [[1,2,3],[4,5,6],[7,8,9]]

In [144]: newLi = [x for para in nestLi for x in para]

In [145]: newLi
Out[145]: [1, 2, 3, 4, 5, 6, 7, 8, 9]

等效于

newLi = []
nestLi = [[1,2,3],[4,5,6],[7,8,9]]
for para in nestLi:
    for x in para:
        newLi.append(x)

print newLi

还可以像下面这样求一个范围内的随机值。

In [3]: from random import randint

In [4]: [randint(1, 10) for i in range(2)]
Out[4]: [10, 4]

In [5]: [randint(1, 10) for i in range(2)]
Out[5]: [7, 8]

In [6]: [randint(1, 10) for i in range(2)]
Out[6]: [3, 4]

In [7]: [randint(1, 10) for i in range(2)]
Out[7]: [10, 8]

In [8]: [randint(1, 10) for i in range(2)]
Out[8]: [1, 6]

字典的默认值

使用D.get()函数实现。
D.get(k[,d]) -> D[k] if k in D, else d. d defaults to None.

In [153]: dic = {'name':'JMilk','age':23}

In [154]: dic['city'] = dic.get('city','BJ')

In [155]: dic
Out[155]: {'age': 23, 'city': 'BJ', 'name': 'JMilk'}

当一个key(city) not in dict(dic)时,D.get()函数会加入’city’并且使用默认值’BJ’。反之,就不会改变key映射的value。

for…else语句

In [173]: pycat test.py
for x in xrange(5):
    if x == 5:
        print 'I can find 5!'
else:
    print 'I cannot find 5!'

In [174]: run test.py
I cannot find 5!

在Python不仅是if语句可以配合使用else语句,for、while语句也可以使用。else语句用来处理跳出上个语句块后的情况,有了else,我们可以不用繁复的去设置状态变量来检查是否程序流是否有重上一个语句块跳出,简单方便。这是Python重视使用真值表应用的一个体现。

交换两个变量的值

In [1]: value1 = 1

In [2]: value2 = 2

In [3]: value1,value2 = value2,value1

In [4]: value1,value2
Out[4]: (2, 1)

别的语言就会需要一个设置中间变量来完成变量值的交换。

链式比较

In [30]: value1 < value2 < 3
Out[30]: True

可以使用任意的算术比较运算符

真值测试

Python真值表在运算符详解篇已经有过了介绍,传送门:http://blog.csdn.net/jmilk/article/details/48666475

In [36]: name = 'Jmilk'

In [37]: dic = {'age': 23, 'name': 'Jmilk'}

In [38]: li = ['Hi','Jmilk']

In [39]: if name and dic and li:
   ....:     print 'All True!'
   ....:     
All True!

在if语句中,能够写入任意对象,且会直接根据真值表(非0,非空容器类型对象的值为True)来判断其真假,而不一定需要写入判断的条件。

序列类型元素反转

In [51]: str
Out[51]: 'Hello JMilk!'

In [52]: li
Out[52]: ['Hi', 'Jmilk']

In [53]: tup = ('hello','world!')

In [54]: str[::-1]
Out[54]: '!kliMJ olleH'

In [55]: li[::-1]
Out[55]: ['Jmilk', 'Hi']

In [56]: tup[::-1]
Out[56]: ('world!', 'hello')

这样做的效率会更高,且进行回文检时,只需要inport == inport[::-1]就可以完成。
回文:正读和反读都相同的字符序列

连接字符串和列表

在Python只需要使用String.join()方法就可以实现将字符串插入到列表的每个元素之间,再返回一个新的字符串。

In [70]: str = ' '

In [71]: li
Out[71]: ['Hi', 'Jmilk']

In [72]: str.join(li)
Out[72]: 'Hi Jmilk'

Python一切皆对象的思想,造就了非常多的针对数据类型的内建函数。

内置算术函数

Python除了有大量的模块之外,还有着丰富的内置函数。
求和

In [1]: num = [1,2,3]

In [2]: sum(num)
Out[2]: 6

最大值

In [3]: max(num)
Out[3]: 3

最小值

In [4]: min(num)
Out[4]: 1

乘积

In [84]: from operator import mul

In [85]: reduce(mul,range(1,5),1)
Out[85]: 24

短短的一条语句就能实现1*2*3*4,而且这些简短的语句拥有着更高的执行效率。
求绝对值

In [1]: a = -100

In [2]: abs(a)
Out[2]: 100

求商、余数

In [6]: divmod(10,3)
Out[6]: (3, 1)   #商==3;余数==1

求平方

In [11]: pow(2,4)
Out[11]: 16        #相当于 2**4

In [12]: pow(2,4,5)
Out[12]: 1         #相当于 2**4%5

求浮点数

In [14]: round(1)
Out[14]: 1.0

利用zip()来创建键值对

zip(seq1 [, seq2 […]]) -> [(seq1[0], seq2[0] …), (…)]
将两个序列参数,转换成Tuple和List的组合。

In [175]: keys = ['Name', 'Sex', 'Age']

In [176]: values = ['Tim', 'Male', 23]

In [177]: zip(keys, values)
Out[177]: [('Name', 'Tim'), ('Sex', 'Male'), ('Age', 23)]

In [178]: dict(zip(keys,values))
Out[178]: {'Age': 23, 'Name': 'Tim', 'Sex': 'Male'}

最后

利用本篇介绍的一些Python的特性,能使程序 写法更加简练、高效和更少的代码量。

Jmilk

相关文章
|
21小时前
|
机器学习/深度学习 人工智能 数据可视化
Python:探索编程之美
Python:探索编程之美
8 0
|
1天前
|
机器学习/深度学习 人工智能 数据处理
Python编程的魅力与实践
Python编程的魅力与实践
|
2天前
|
SQL 关系型数据库 MySQL
第十三章 Python数据库编程
第十三章 Python数据库编程
|
2天前
|
存储 网络协议 关系型数据库
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
|
7天前
|
安全 数据处理 开发者
《Python 简易速速上手小册》第7章:高级 Python 编程(2024 最新版)
《Python 简易速速上手小册》第7章:高级 Python 编程(2024 最新版)
19 1
|
7天前
|
人工智能 数据挖掘 程序员
《Python 简易速速上手小册》第1章:Python 编程入门(2024 最新版)
《Python 简易速速上手小册》第1章:Python 编程入门(2024 最新版)
35 0
|
8天前
|
API Python
Python模块化编程:面试题深度解析
【4月更文挑战第14天】了解Python模块化编程对于构建大型项目至关重要,它涉及代码组织、复用和维护。本文深入探讨了模块、包、导入机制、命名空间和作用域等基础概念,并列举了面试中常见的模块导入混乱、不适当星号导入等问题,强调了避免循环依赖、合理使用`__init__.py`以及理解模块作用域的重要性。掌握这些知识将有助于在面试中自信应对模块化编程的相关挑战。
21 0
|
9天前
|
Python
Python金融应用编程:衍生品定价和套期保值的随机过程
Python金融应用编程:衍生品定价和套期保值的随机过程
24 0
|
9天前
|
Python
python面型对象编程进阶(继承、多态、私有化、异常捕获、类属性和类方法)(上)
python面型对象编程进阶(继承、多态、私有化、异常捕获、类属性和类方法)(上)
52 0
|
10天前
|
机器学习/深度学习 算法 定位技术
python中使用马尔可夫决策过程(MDP)动态编程来解决最短路径强化学习问题
python中使用马尔可夫决策过程(MDP)动态编程来解决最短路径强化学习问题
24 1