python 语法
1:输出数据print 'hello world!'
print "hello world!"
print 'hello %s!' %('world') %d表示数字占位符(print type("")可以查看类型)
如何输出%
print 'hello %s! %%' %('world')
2:if
a = 1; b = 2
if(a == b) :
print 'a == b'
elif (a > b) :
print 'a > b'
elif (a < b) :
print 'a < b'
else :
print '#@)#$'
3:for while (流程控制:break跳出,continue跳出一次)
array =
total = 0
for a in array:
total += a #python是用四个空格做缩进的,格式要严格
print total
# -----分割线--------
while 1 > 2:
pass
4:数组(链表)
# 链表结构
array =
total = 0
for a in array:
total += a
print total
5:set(散列)
# 散列结构,无重复值
print set( ) # 去重
set1 = set()
set2 = set()
print set1 - set2 # set1有,set2没有
print set1 & set2 # set1和set2的交集
print set1 | set2 # set1和set2的并集
6:map(字典)
# key value结构
dict={}
dict['zs'] = 21
dict['ls'] = 25
dict['ww'] = 22
for key in dict.keys():
print '%s %d' %(key, dict)
7:方法
def main():
pass
if __name__ == '__main__':
main()
8:文件操作
f = file("c:/client_log.txt","r")
print f.read()
f.close()#传统的须要关闭数据流
with open("c:/client_log.txt","r") as f:
print f.read()
with open("c:/yy.txt","w") as f:
f.write("i'am OK!")
一次读一行
def main(json_one):
f=open("c:/aa.txt","r")
for line in f:
line = line.strip()#去掉多首尾多于的空白符
f.close()
9:读取网络信息
#coding:utf-8
import json
import urllib
defget_rcms_api(user_name): #命名要规范(错getRcmsApi)
# user_name='qq'
url='http://rcmsapi.chinacache.com:36000/customer/'+user_name+'/channels'
maps=urllib.urlopen(url).read()
json_array=json.loads(maps)
for channel_dict in json_array:
print 'url: %s ' %(channel_dict['name'])
if __name__ == '__main__':
get_rcms_api('qq')
10:简单转码
user_name.encode('utf-8')
详情:http://blog.csdn.net/samxx8/article/details/6286407
11:数组的快速创建:
channel= for i in json_obj]
12:数组的哪一种遍历
a = ['Mary', 'had', 'a', 'little', 'lamb']
>>> for i in range(len(a)):
... print i, a
13:字符数字转换
int --> str
直接使用 str(123); 把123 转成“123”
str --> int
string.atoi("123") 把“123”转成123
14:type还可以这样搞
all_bandwidth=[]
print cmp(str(type(all_bandwidth)),"<type 'list'>")==0 #true
15:None是值,pass是空语句
16:range:
range( stop [, step])
# start 可选参数,起始数
#stop 终止数,如果 range 只有一个参数x,则产生一个包含 0 至 x-1 的整数列表
#step 可选参数,步长
17:快速创建符合条件的数组
求list列表偶数和(一行)
>>> a =
>>> print sum() #多个条件可用and or 连接
18:python全局变量(python全局变量在函数和类定义外面,如果某个函数或类想使用这个全局变量,需要添加global 关键字加以说明,否则就是重新定义了一个和全局变量名字相同的局部变量)
a = 2
def change():
global a
a = 3
print a
print a
change()
print a
结果
2
3
3
19:目录操作
os模块
remove()/unlink() 删除文件
rename()/renames() 重命名文件
walk() 生成一个目录树下的所有文件名
listdir() 列出指定目录的文件
mkdir()/makedirs() 创建目录/创建多层目录
rmdir()/removedirs() 删除目录/删除多层目录
os.path模块
basename() 去掉目录路径,返回文件名
dirname() 去掉文件名,返回目录路径
join() 将分离的各部分组合成一个路径名
split() 返回(dirname(), basename())元组
splitdrive() 返回(drivename, pathname)元组
splitext() 返回(filename, extension)元组
exists() 指定路径(文件或目录)是否存在
isabs() 指定路径是否为绝对路径
isdir() 指定路径是否是目录
isfile() 指定路径是否为文件
通过正则得到文件名:glob.glob(r"???*[]"+current_dir)
current_dir=os.getcwd()+"/???_20130909.txt"
files = glob.glob(r""+current_dir) #get file list by diretory
得到目录下的文件个数
sum() #os.walk(dir)会返回一个三元组:(当前目录,子目录列表,文件列表)
文件更新时间
import os,time
time.ctime(os.stat("d:/learn/flash.txt").st_mtime) #文件的修改时间
time.ctime(os.stat("d:/learn/flash.txt").st_ctime) #文件的创建时间
得到时间戳(单位是秒,可用当前时间减去它来得到文件多长时间没有更新)
time.time()-os.stat("d:/learn/flash.txt").st_mtime
20:提前退出
exit()
21:一些函数
round(float(data)/1000000,2)
float(data)
int(data)
str(data)
22:得到用户传递的参数
sys.argv
运行:python catBandError.py 18545 a
结果:catBandError.py #0是文件名
18545
a
23:随机数
# -*- coding: utf-8 -*-
import random
import sys
def gettime():
printrandom.random();#0~1之间的随机数
print random.uniform(1, 10);#1~10之间的随机小数
print random.randrange(0, 101, 2); #0~101之间的随机偶数
print random.randint(10, 100);#10~100之间的随数整数
print random.choice('abcdefg&#%^*f');#字符串中随机取一个字符
print random.choice ( ['apple', 'pear', 'peach', 'orange', 'lemon'] );#数组中随机取一个字符串
p=['apple', 'pear', 'peach', 'orange', 'lemon']
random.shuffle(p);#打散数组
print p
print random.sample('sequence', 2);#字符串中随机取2个组成一个字符数组
if __name__ == '__main__':
reload(sys)
sys.setdefaultencoding('utf-8')
gettime();
页:
[1]