当前位置:Gxlcms > Python > Python的一些小练习

Python的一些小练习

时间:2021-07-01 10:21:17 帮助过:32人阅读

作业一

利用*字典*输出目录,可以选择目录进入,可以回退、退出!

  1. <span style="color: #808080; font-style: italic">#conding:utf8<span style="color: #000080; font-weight: bold"><br><br><br>menu = {<span style="color: #008080; font-weight: bold">'北京':{<span style="color: #008080; font-weight: bold">'昌平':{<span style="color: #008080; font-weight: bold">'沙河':{<span style="color: #008080; font-weight: bold">'昌平妇幼',}},<span style="color: #008080; font-weight: bold">'海淀':{<span style="color: #008080; font-weight: bold">'海淀一区':{<span style="color: #008080; font-weight: bold">'海淀二区'},}},} <span style="color: #808080; font-style: italic">#字典嵌套<br><span style="color: #808080; font-style: italic"><br>current_layer = menu <span style="color: #808080; font-style: italic">#利用此变量来记录当前的层的位置<br>pre_menu = [] <span style="color: #808080; font-style: italic">#用【】来记录每一层<br><span style="color: #808080; font-style: italic"><br><span style="color: #000080; font-weight: bold">while True:<br><span style="color: #000080; font-weight: bold">for k <span style="color: #000080; font-weight: bold">in current_layer:<br><span style="color: #000080">print (k)<br> choice = <span style="color: #000080">input(<span style="color: #008080; font-weight: bold">'>>>>>>>:').strip() <span style="color: #808080; font-style: italic">#去除输入选项连边的空格<br><span style="color: #808080; font-style: italic"> <span style="color: #000080; font-weight: bold">if <span style="color: #000080">len(choice) == <span style="color: #0000ff">0: <span style="color: #808080; font-style: italic">#通过len的长度来判断用户是否输入了<br><span style="color: #808080; font-style: italic"> <span style="color: #000080; font-weight: bold">continue<br><span style="color: #000080; font-weight: bold"><br><span style="color: #000080; font-weight: bold"> if choice <span style="color: #000080; font-weight: bold">in current_layer:<br> pre_menu.append(current_layer)<br> current_layer = current_layer[choice]<br><span style="color: #000080; font-weight: bold">elif choice == <span style="color: #008080; font-weight: bold">'b':<br><span style="color: #000080; font-weight: bold">if <span style="color: #000080">len(pre_menu) > <span style="color: #0000ff">0: <span style="color: #808080; font-style: italic">#通过大于0 来判断,还有目录可退<br><span style="color: #808080; font-style: italic"> current_layer = pre_menu.pop() <span style="color: #808080; font-style: italic">#利用pop来弹出上面的一层。<br><span style="color: #808080; font-style: italic"> <span style="color: #000080; font-weight: bold">elif choice == <span style="color: #008080; font-weight: bold">'q':<br><span style="color: #000080">exit()</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

作业二

list的小练习:实现购物车功能

  1. product_list = [[

作业三

冒泡算法小练习

  1. a_list = [

作业四

插入算法小练习

实现方法一

  1. a_list = [

实现方法二

  1. arr1 = [

做业五

打印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

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

作业六:

取一个列表中前两位大的数字

  1. <br>
  1. <span style="color: #808080; font-style: italic">#!/usr/bin/python<br><span style="color: #808080; font-style: italic"><br>NumList = [<span style="color: #0000ff">1,<span style="color: #0000ff">2,<span style="color: #0000ff">3,<span style="color: #0000ff">2,<span style="color: #0000ff">12,<span style="color: #0000ff">3,<span style="color: #0000ff">1,<span style="color: #0000ff">3,<span style="color: #0000ff">21,<span style="color: #0000ff">2,<span style="color: #0000ff">2,<span style="color: #0000ff">3,<span style="color: #0000ff">4111,<span style="color: #0000ff">22,<span style="color: #0000ff">3333,<span style="color: #0000ff">444,<span style="color: #0000ff">111,<span style="color: #0000ff">4,<span style="color: #0000ff">5,<span style="color: #0000ff">777,<span style="color: #0000ff">4222,<span style="color: #0000ff">46,<span style="color: #0000ff">33,<span style="color: #0000ff">45,<span style="color: #0000ff">65555]<br><br>max_num = <span style="color: #0000ff">0<br>sec_num = <span style="color: #0000ff">0<br><span style="color: #0000ff"><br><span style="color: #000080; font-weight: bold">for n <span style="color: #000080; font-weight: bold">in NumList:<br><span style="color: #000080; font-weight: bold">if max_num < n:<br> sec_num=max_num <br><span style="color: #808080; font-style: italic">#获取最大数之前的比较的哪个数肯定是在这之前第二大的<br><span style="color: #808080; font-style: italic"> max_num = n<br><span style="color: #808080; font-style: italic">#但是后面如果再出现比最大的大,比之前比较出料的第二大<br><span style="color: #808080; font-style: italic"> #小的数时需要再比较下。<br><span style="color: #808080; font-style: italic"> <span style="color: #000080; font-weight: bold">if n < max_num <span style="color: #000080; font-weight: bold">and n > sec_num:<br> sec_num = n<br><br><br><span style="color: #000080">print (<span style="color: #008080; font-weight: bold">'The bigest NUM is : %s' %(max_num))<br><span style="color: #000080">print (<span style="color: #008080; font-weight: bold">'The second one is : %s' %(sec_num))</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
  1. <br>

利用单循环来同事去除两个两个数。

作业七

二分查找法(利用递归函数)

  1. num_list = [

作业八

利用函数完成用户的注册登录功能

#!/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输出

  1. #!/usr/bin/python
  2. #coding:utf8
  3. def openFile(log):
  4. with open(log) as f:
  5. content = f.readlines()
  6. return content
  7. def countLine(fn):
  8. content = fn
  9. count_dict = {}
  10. for line in content:
  11. line = line.split(' ') # string 通过split 转换为list
  12. local_ip,uri,code = line[0],line[6],line[8]
  1. #利用元组来作为key,然后统计数量
  1. count_dict[(local_ip,uri,code)] = count_dict.get((local_ip,uri,code),0) + 1
  1. #这个排序的功能网上copy的,不了解原理
  1. count_dict = sorted(count_dict.items() ,key=lambda item:item[1],reverse=True)
  2. return count_dict
  3. def detailLine(fn):
  4. count_dict = fn
  5. #下面进行重复行计数为一行。
  6. n = 1 #取行计数
  7. num = 0 #用于判断'统计数量'是否出现一样的
  8. # print ('-----IP------------------URI----------CODE---count---')
  9. # for i in count_dict:
  10. # if n <= 10: # 取前十
  11. # if i[1] != num:
  12. # print('%-10s%20s%5s%10s ---->no%s' % (i[0][0], i[0][1], i[0][2], i[1], n))
  13. # num = i[1]
  14. # n += 1
  15. # elif i[1] == num:
  16. # print('%-10s%20s%5s%10s' % (i[0][0], i[0][1], i[0][2], i[1]))
  17. with open('count.html','w') as f:
  18. res = "<table border='1'>"
  19. res += '<tr><td>IP</td><td>URI</td><td>CODE</td><td>COUNT</td></tr>'
  20. for i in count_dict:
  21. if n <= 10:
  22. if i[1] != num:
  23. res += '<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>'% (i[0][0],
  24. i[0][1], i[0][2], i[1])
  25. num = i[1]
  26. n += 1
  27. elif i[1] == num:
  28. res += '<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>' % (i[0][0],
  29. i[0][1], i[0][2], i[1])
  30. res +='</table>'
  31. f.write(res)
  32. def main():
  33. first = openFile('access.log')
  34. second = countLine(first)
  35. detailLine(second)
  36. if __name__ == '__main__':
  37. main()
作业十,

生成随机验证码:

  1. 方法一:
  2. import string,random
  3. source = string.digits + string.ascio_lowercase
  4. print ("".join(random.sample(source,6)))
  5. 方法二:
  6. checkcode = ''
  7. for i in range(6):
  8. current = random.randrange(0,6)
  9. if current != i:
  10. temp = chr(random.randint(65,90))
  11. else:
  12. temp = random.randint(0-9)
  13. checkcode += str(temp)
  14. print(checkcode)

以上就是Python的一些小练习的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行