静态类型语言
一种在编译期间就确定数据类型的语言。大多数静态类型语言是通过要求在使用任一变量之前声明其数据类型来保证这一点的。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[s] += 1
except KeyError: count[s] = 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命令,且返回结果。