设为首页 收藏本站
云服务器等爆品抢先购,低至4.2元/月
查看: 534|回复: 0

[经验分享] python 小技巧

[复制链接]

尚未签到

发表于 2017-4-23 09:19:09 | 显示全部楼层 |阅读模式
静态类型语言
    一种在编译期间就确定数据类型的语言。大多数静态类型语言是通过要求在使用任一变量之前声明其数据类型来保证这一点的。Java和C是静态类型语言。
动态类型语言
    一种在运行期间才去确定数据类型的语言,与静态类型相反。VBScript和Python是动态类型的,因为它们确定一个变量的类型是在您第一次给它赋值的时候。
强类型语言
    一种总是强制类型定义的语言。Java和Python是强制类型定义的。您有一个整数,如果不明确地进行转换 ,不能将把它当成一个字符串。
弱类型语言
    一种类型可以被忽略的语言,与强类型相反。VBScript是弱类型的。在VBScript中,您可以将字符串'12'和整数3进行连接得到字符串'123',然后可以把它看成整数123,所有这些都不需要任何的显示转换。

所以说Python既是动态类型语言(因为它不使用显示数据类型声明),又是强类型语言(因为只要一个变量获得了一个数据类型,它实际上就一直是这个类型了)。
现在总的趋势语言都在向动态语言类型靠近,这的确大大方便了程序员,使得编写程序更方便,效率更高,动态语言你不必关心变量的类型.java也可以达到一定程度的动态识别.比如多态,但你必须要有继承关系,还有反射,繁琐并且效率低,如果使用python,这些方面的问题就很容易解决了.
下面我就细化的总结下python的优点:
1)函数
在函数方面python是做的比较好的,好的地方主要在支持默认参数和关键参数.
简单例子:
Python代码

   1. def function_test(a,b=3,c=5):  
   2.     """docstring for function_test"""  
   3.     print a  
   4.     print b  
   5.     print c  

def function_test(a,b=3,c=5): """docstring for function_test""" print a print b print c
调用function_test(1) ,结果 1, 3, 5
调用function_test(1,c=2,b=3) 结果 1,3,2
2)集合
显然在集合方面python也有很大的优势.操作简便,集合类可以放不同类型的元素.
集合在python中分为:dictionary.list.tuple,操作非常的方便.
想想在java里如果要篇历一个map的key ,value是多么的麻烦.但是在python中
一句搞定.
"|".join(["%s=%s" % (k, v) for k, v in params.items()])
params是一个字典.params.items()返回这个字典的key,value ,每个key,value为一个元组.k,v
3)一次赋多值
这是个很方便的功能,可以一次给多个变量赋值,有些时候是非常有用的
Python代码

   1. def  mulequ():  
   2.     """docstring for  mulequ"""  
   3.     (one,two,three) =  range(3)  
   4.     print(one,two,three)  

def mulequ(): """docstring for mulequ""" (one,two,three) = range(3) print(one,two,three)
调用mulequ(),结果是(0, 1, 2)
4)映射list
这是Python对于list提供的非常强大的方法,可以对list进行解析.并且映射为另一个list.
Python代码

   1. li=[1,2,3,4,5]  
   2. li_1 = [element*2 for element in  li]  
   3. print li_1   

li=[1,2,3,4,5] li_1 = [element*2 for element in li] print li_1
结果是 2,4,6,8,10
to becontinued......

-------------------------------------------------------------

方便日后查阅。
import sqlite3
conn=sqlite3.connect('test.db')
cur=conn.cursor()
cur.execute("create table test (id int,char1 varchar(10),char2 varchar(10),da text)")
cur.execute("insert into test values (1,'a','b','chhfhfhh')")
t='aaaa'
cur.execute("insert into test values (5,'%s','%s','%s')" % (t,t,t))  # 插入变量
cur.execute('select * from test') 查询
a=cur.fetchall()
for i in a:
print i
conn.commit()  提交,相当于保存
cur.close()
conn.close()
2进制到10进制:
int(str(1011), 2)
10进制到2进制:
def bin(num):
if num == 0: return '0' return "".join([str((num>>i)&1) for i in xrange(int(math.floor(math.log(num, 2))),-1,-1)])
10进制到16
hex(111)  可以是数字,不能为字母
16进制到10
int('aa',16)
print binascii.b2a_hex('A')   字母A的ASCII码
print binascii.a2b_hex('41')  41的ASCII字符

import PIL.Image
PIL.Image.open('d:\\a.jpg').save('d:\\b.gif')
转换jpg文件为gif

import random
import string
#随机整数:
print random.randint(1,50)
#随机选取0到100间的偶数:
print random.randrange(0, 101, 2)
#随机浮点数:
print random.random()
print random.uniform(1, 10)
#随机字符:
print random.choice('abcdefghijklmnopqrstuvwxyz!@#$%^&*()')
#多个字符中选取特定数量的字符:
print random.sample('zyxwvutsrqponmlkjihgfedcba',5)
#多个字符中选取特定数量的字符组成新字符串:
print string.join(random.sample(['z','y','x','w','v','u','t','s','r','q','p','o','n','m','l','k','j','i','h','g','f','e','d','c','b','a'], 5)).replace(' ','')
#随机选取字符串:
print random.choice(['剪刀', '石头', '布'])
#打乱排序
items = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]
print random.shuffle(items)
数据压缩
import zlib
s='witch which has which whih abc google'
len(s)
t=zlib.compress(s)
len(t)
r=zlib.decompress(t)
zlib.crc32(s)
import tkFileDialog, os, sys
filename = tkFileDialog.askopenfilename(initialdir=os.getcwd())
相当于WINDOWS的浏览,选择文件
sys.getdefaultencoding()  获取默认编码
reload(sys)是因为Python2.5 初始化后会删除 sys.setdefaultencoding 这个方法,我们需要重新载入
sys.setdefaultencoding('utf8')  设置默认编码

正则表达式
s='abcdefg'
ss=re.sub(r'(.)',r'\1 ',s)
ss='a b c d e f g'
提取URL:
com=re.compile(r'<a.*?href=["\']?\s?(.*?)["\'\s]?>',re.I|re.M|re.S)
urls=com.findall(ss)
import os   #查找目录
a=os.listdir(os.getcwd())
for i in a:
if os.path.isdir(i):
  print i
复制对象
import copy
a=[1,3,5]
b=copy.copy(a)
c=a[:]
组合
s='abcdefg'
for i in range(len(s)):
for j in range(len(s)-i+1):
  print s[i:i+j]
urllib.urlopen(url, proxies={'http' : 'http://address:port'})  使用代理

import sys
sys.path.append('/home/lcg/mylib') 添加路径
退出
exit()
不用import sys了
如果是在while里面,只要break
将list的每一个元素转为string
l=[1,3,5,6,5]
map(str,l)
print 'hi' #会自动换行
import sys
sys.stdout.write('hi')
sys.stdout.write('hi\n')  #不会自动换行

urllib超时问题解决
import socket
socket.setdefaulttimeout(30)

import webbrowser
webbrowser.open('http://www.baidu.com')  调用默认浏览器打开网页
import os
os.system('start http://www.baidu.com')

1/8  =0
1.0/8  =0.125

LINUX:
    import struct
    import socket
    import fcntl
    def getLocalIp(ifname="eth0"):
        sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        return socket.inet_ntoa(fcntl.ioctl(sock.fileno(), 0x8915,  # SIOCGIFADDR
        struct.pack('256s', ifname[:15]))[20:24])
    print getLocalIp("eth0")
    >>>59.64.136.xxx
import hashlib
a=hashlib.md5('a').hexdigest()
import md5   MD5加密  旧,不推荐
a=123444   
b=str(a)
c=md5.new(b).hexdigest()

>>> items = ['town', 'apple', 'car', 'phone']
>>> values = [7, 5, 2, 1]
>>> *values,items = zip( *sorted( zip (values,items)))
a=[1,35,6]
b=['a','b','g']
c=zip(a,b)   合并列表
Windows:      查看本地IP地址
    import socket
    print socket.gethostbyname(socket.gethostname())   
import uuid    # python2.5
uuid.uuid1().hex[-12:] 即可查看本机的MAC地址.
python2.4没有uuid
可以用os+re做,网上有源码  mac.py
b=re.findall('IP Address.*?([\d]{1,3}\.[\d]{1,3}\.[\d]{1,3}\.[\d]{1,3})', a,re.DOTALL)  ip
c=re.findall('Subnet Mask.*?([\d]{1,3}\.[\d]{1,3}\.[\d]{1,3}\.[\d]{1,3})', a,re.DOTALL)  子网掩码
d=re.findall('Default Gateway.*?([\d]{1,3}\.[\d]{1,3}\.[\d]{1,3}\.[\d]{1,3})', a,re.DOTALL)  网关
b=re.findall('DNS Servers.*?([\d]{1,3}\.[\d]{1,3}\.[\d]{1,3}\.[\d]{1,3})', a,re.DOTALL)   dns1
dns=re.findall('DNS Servers.*?([\d]{1,3}\.[\d]{1,3}\.[\d]{1,3}\.[\d]{1,3}\s*[\d]{1,3}\.[\d]{1,3}\.[\d]{1,3}\.[\d]{1,3})', a,re.DOTALL)
dnss=re.split('\s*',dns[0])  dnss[0],dnss[1]

十六进制反码: 0x1111
0x1111 ^ 0xffff
s='abcdefg'
list(s)
l=['a','b','c']
' '.join(l)
profile模块计算函数运行时间
importt profile
def a():
for i in range(1000):
  pass
profile.run('a')  
count ={}   # 统计单词出现的次数
for s in l:
    try: count += 1
    except KeyError: count = 1
print chr(7) #响一下。

相信很多写C的人都会经常用到C的三元操作符吧,如下
var = (condition) ? a : b; #c代码
在python中,你可以这样写:
var = condition and a or b 也可以是下面
var=x if x>y else y

sys.argv   获取命令行下输入的参数
path = os.path.join(os.path.dirname(__file__), 'index.html')

import os
a=os.popen('netstat')
b=a.readlines()
for i in b:
print i
# 执行CMD命令,且返回结果。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-368019-1-1.html 上篇帖子: Python新手笔记之python迭代器遍历列表 下篇帖子: Python: Singleton 模式
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表