Python小课题练习作业
作业一:
利用*字典*输出目录,可以选择目录进入,可以回退、退出!
#conding:utf8
|
作业二
list的小练习:实现购物车功能
product_list = [['iphone',6500],['Mobli',5000],['huawei',4000],['oppo',300],['vivo',100]]
|
作业三
冒泡算法小练习
a_list = [9,8,7,6,5,4,3,2,1]
|
作业四
插入算法小练习
实现方法一:
a_list = [3 ,66 ,3 ,41 ,34 ,6 ,7 ,845 ,234 ,31]
|
实现方法二:
arr1 = [10,9,8,7,6,5,4,3,2,1]
|
做业五
打印99乘法表
#! /usr/bin/python
# Filename : table_9x9.py
print '\n9x9 Table\n'
for i in range(1, 10) :
for j in range(1, i+1) :
print j, 'x', i, '=', j*i, '\t',
# print '%d x %d = %d\t' %(j, i, j*i),
print '\n'
print '\nDone!'
关于该程序的说明:
1. 第一行是特殊注释行,称为组织行,用来告诉GNU/Linux系统应该使用哪个解释器来执行该程序。
2. 第二行至第四行都是一般的注释行,用来说明一些信息的(如文件名,作者,时间等)。
3. 第六行打印一个字符串。
4. 第八行i取值范围为1, 2, 3, 4, 5, 6, 7, 8, 9
5. 第九行j取值范围为1, 2, ..., i
6. 第十行和第十一行效果一样,最后的逗号都是用来取消自动换行的。
7. 第十二行作用是在每个内层for循环结束后换行,即在输出完九九乘法表一行后换行。
8. 第十四行打印一个字符串。
小结:通过这个程序熟悉print的用法,for循环的用法,以及range函数的特点。
|
课堂中提到的方法:
for i in range(1,10):
output = ''
for j in range(1,i+1):
output+= "%s*%s=%2s "%(i,j,i*j)
print output
---------------------------------------------------
作业六:
取一个列表中前两位大的数字
#!/usr/bin/python
|
利用单循环来同事去除两个两个数。
作业七
二分查找法(利用递归函数)
num_list = [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,20,21,22]
|
作业八
利用函数完成用户的注册登录功能
#!/usr/bin/python
#encoding: utf-8
import getpass
user_list = {}
def new_user():
username = raw_input('please input your new name:')
if username in user_list:
print '%s is already exits!!' %username
else:
passwd = getpass.getpass() #已密码不显示的方式输入。
user_list[username] = passwd
def old_user():
username = raw_input('please input your name:')
passwd = raw_input('please input your passwd:')
if username in user_list:
if user_list[username] == passwd:
print 'login successfull!!'
else:
print 'login fail!!'
else:
print 'login fail!!!'
CMD = {'n' : new_user , 'o' : old_user}
def main_menu():
ppp = '''
新用户注册:n
老用户登录:o
推出:q
'''
while True:
try:
choice = raw_input(ppp)
except (KeyboardInterrupt, EOFError): #捕捉ctrl+ D 的错误输出。
choice = 'q'
if choice not in 'noq':
print 'please input again'
continue
if choice == 'q':
break
CMD[choice]() #通过取字典的key,选择来执行函数
if __name__ == '__main__':
main_menu()
作业九 |
log日志前十排序,其中包括重复的。利用函数简单的html输出
#!/usr/bin/python
#coding:utf8
def openFile(log):
with open(log) as f:
content = f.readlines()
return content
def countLine(fn):
content = fn
count_dict = {}
for line in content:
line = line.split(' ') # string 通过split 转换为list
local_ip,uri,code = line[0],line[6],line[8]
#利用元组来作为key,然后统计数量
count_dict[(local_ip,uri,code)] = count_dict.get((local_ip,uri,code),0) + 1
#这个排序的功能网上copy的,不了解原理
count_dict = sorted(count_dict.items() ,key=lambda item:item[1],reverse=True)
return count_dict
def detailLine(fn):
count_dict = fn
#下面进行重复行计数为一行。
n = 1 #取行计数
num = 0 #用于判断'统计数量'是否出现一样的
# print ('-----IP------------------URI----------CODE---count---')
# for i in count_dict:
# if n <= 10: # 取前十
# if i[1] != num:
# print('%-10s%20s%5s%10s ---->no%s' % (i[0][0], i[0][1], i[0][2], i[1], n))
# num = i[1]
# n += 1
# elif i[1] == num:
# print('%-10s%20s%5s%10s' % (i[0][0], i[0][1], i[0][2], i[1]))
with open('count.html','w') as f:
res = "<table border='1'>"
res += '<tr><td>IP</td><td>URI</td><td>CODE</td><td>COUNT</td></tr>'
for i in count_dict:
if n <= 10:
if i[1] != num:
res += '<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>'% (i[0][0],
i[0][1], i[0][2], i[1])
num = i[1]
n += 1
elif i[1] == num:
res += '<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>' % (i[0][0],
i[0][1], i[0][2], i[1])
res +='</table>'
f.write(res)
def main():
first = openFile('access.log')
second = countLine(first)
detailLine(second)
if __name__ == '__main__':
main()
作业十, |
生成随机验证码:
方法一:
import string,random
source = string.digits + string.ascio_lowercase
print ("".join(random.sample(source,6)))
方法二:
checkcode = ''
for i in range(6):
current = random.randrange(0,6)
if current != i:
temp = chr(random.randint(65,90))
else:
temp = random.randint(0-9)
checkcode += str(temp)
print(checkcode)
作业十一 |
利用快排,来对列表数字进行排序。
a = [ 65,2,1,3,6,1,3,4,1,3,6,7,8243,3]
def kuaipai(arr):
if len(arr) <= 1:
return arr
num = arr.pop() #在列表中pop弹出一个对象来,作为比较的对象,然后列表中就少了这个对象
left = []
right = []
for i in arr: #因为里面已经没有了需要比较的对象,所以可以直接循环列表来比较。
if num > i:
left.append(i)
else:
right.append(i)
return kuaipai(left) + [num] + kuaipai(right) #用到了函数的递归
print kuaipai(a)
运行结果:
[1, 1, 1, 2, 3, 3, 3, 3, 4, 6, 6, 7, 65, 8243]