python总结(拷贝)

不错的python总结,有时间转过来

http://www.iteye.com/topic/427429

这篇文章只是简单的增加了一些内容,其中包括之前的那一篇总结。为了防止日后重装系统清空硬盘,贴上网,方便日后查阅。

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命令,且返回结果。



http://ipython.iteye.com/blog/359368


很久没有写blog了,现在将我一直以来的总结贴出来,希望对大家用有。现在作业比较多,没有时间事理了。 
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)]) 

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.setdefaultencoding('utf8') 

正则表达式 
s='abcdefg' 
ss=re.sub(r'(.)',r'\1 ',s) 
ss='a b c d e f g' 

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值