Python基础教程——60个基础练习(二)

21-while-break

break 是结束循环,break 之后、循环体内代码不再执行。

while True:       
yn = input('Continue(y/n): ')       
if yn in ['n', 'N']:           
break       
print('running...')   

22-while-continue

计算 100 以内偶数之和。

continue 是跳过本次循环剩余部分,回到循环条件处。

sum100 = 0   
counter = 0    
     
while counter < 100:       
counter += 1       # if counter % 2:       
if counter % 2 == 1:           
continue       
sum100 += counter     
    
print(sum100)   

23-for 循环遍历数据对象

astr = 'hello'   
alist = [10, 20, 30]   
atuple = ('bob', 'tom', 'alice')   
adict = {
    
    'name': 'john', 'age': 23}   
      
for ch in astr:       
print(ch)         

for i in alist:       
print(i)         

for name in atuple:       
print(name)         

for key in adict:       
print('%s: %s' % (key, adict[key]))   

24-range 用法及数字累加

# range(10)  
# [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]   
# >>> list(range(10))   
# range(6, 11)  
# [6, 7, 8, 9, 10]   
# range(1, 10, 2)  
# [1, 3, 5, 7, 9]   
# range(10, 0, -1)  
# [10, 9, 8, 7, 6, 5, 4, 3, 2, 1]   
sum100 = 0         

for i in range(1, 101):       
sum100 += i         

print(sum100)   

25-列表实现斐波那契数列

列表中先给定两个数字,后面的数字总是前两个数字之和。

fib = [0, 1]    
     
for i in range(8):       
fib.append(fib[-1] + fib[-2])      
   
print(fib)   

26-九九乘法表

for i in range(1, 10):       
for j in range(1, i + 1):           
print('%s*%s=%s' % (j, i, i * j), end=' ')       
print()         

# i=1 ->j: [1]   
# i=2 ->j: [1,2]   
# i=3 ->j: [1,2,3]   
# 由用户指定相乘到多少   
n = int(input('number: '))      
   
for i in range(1, n + 1):       
for j in range(1, i + 1):           
print('%s*%s=%s' % (j, i, i * j), end=' ')       
print()   

27-逐步实现列表解析

# 10+5 的结果放到列表中   
[10 + 5]   
# 10+5 这个表达式计算 10 次   
[10 + 5 for i in range(10)]   
# 10+i 的 i 来自于循环   
[10 + i for i in range(10)]   
[10 + i for i in range(1, 11)]   
# 通过 if 过滤,满足 if 条件的才参与 10+i 的运算   
[10 + i for i in range(1, 11) if i % 2 == 1]   
[10 + i for i in range(1, 11) if i % 2]  
 # 生成 IP 地址列表   
 ['192.168.1.%s' % i for i in range(1, 255)]   

28-三局两胜的石头剪刀布

import random      
   
all_choices = ['石头', '剪刀', '布']   
win_list = [['石头', '剪刀'], ['剪刀', '布'], ['布', '石头']]   
prompt = """(0) 石头   (1) 剪刀   (2) 布   请选择 (0/1/2): """   
cwin = 0  
pwin = 0    
     
while cwin < 2 and pwin < 2:       
computer = random.choice(all_choices)       
ind = int(input(prompt))       
player = all_choices[ind]  
           
print("Your choice: %s, Computer's choice: %s" % (player, computer))       
if player == computer:           
print('\033[32;1m 平局、033[0m')       
elif [player, computer] in win_list:           
pwin += 1           
print('\033[31;1mYou WIN!!!\033[0m')       
else:           
cwin += 1           
print('\033[31;1mYou LOSE!!!\033[0m')   

29-文件对象基础操作

# 文件操作的三个步骤:打开、读写、关闭   
# cp /etc/passwd /tmp   
f = open('/tmp/passwd')  # 默认以 r 的方式打开纯文本文件   
data = f.read()  # read() 把所有内容读取出来   
print(data)   
data = f.read()  # 随着读写的进行,文件指针向后移动。   
# 因为第一个 f.read() 已经把文件指针移动到结尾了,所以再读就没有数据了   
# 所以 data 是空字符串   
f.close()         

f = open('/tmp/passwd')   
data = f.read(4) 
# 读 4 字节   f.readline()  # 读到换行符、n 结束   
f.readlines()  # 把每一行数据读出来放到列表中   
f.close()        

################################   


f = open('/tmp/passwd')   
for line in f:       
print(line, end='')   
f.close()         
##############################  

 
f = open('图片地址', 'rb')  # 打开非文本文件要加参数 b   
f.read(4096)   
f.close()         
################################## 

  
f = open('/tmp/myfile', 'w')  # 'w'打开文件,如果文件不存在则创建   
f.write('hello world!\n')   
f.flush()  # 立即将缓存中的数据同步到磁盘   
f.writelines(['2nd line.\n', 'new line.\n'])   
f.close()  # 关闭文件的时候,数据保存到磁盘         ##############################   


with open('/tmp/passwd') as f:      
 print(f.readline())         
 #########################   
 
 
 f = open('/tmp/passwd')   
 f.tell()  # 查看文件指针的位置   
 f.readline()   
 f.tell()   
 f.seek(0, 0)  # 第一个数字是偏移量,第 2 位是数字是相对位置。                
 # 相对位置 0 表示开头,1 表示当前,2 表示结尾   
 f.tell()   
 f.close()   

30-拷贝文件

拷贝文件就是以 r 的方式打开源文件,以 w 的方式打开目标文件,将源文件数据读出后,写到目标文件。

以下是【不推荐】的方式,但是可以工作:

f1 = open('/bin/ls', 'rb')   
f2 = open('/root/ls', 'wb')        
 
data = f1.read()   
f2.write(data)      
  
f1.close()   
f2.close()   

31-拷贝文件

每次读取 4K,读完为止:

src_fname = '/bin/ls'   
dst_fname = '/root/ls'         

src_fobj = open(src_fname, 'rb')   
dst_fobj = open(dst_fname, 'wb')         

while True:       
data = src_fobj.read(4096)  # 每次读取 4K       
if not data:           
break       
dst_fobj.write(data)         

src_fobj.close()   
dst_fobj.close()   

32-位置参数

注意:位置参数中的数字是字符形式的

import sys         
print(sys.argv)  # sys.argv 是 sys 模块里的 argv 列表         
# python3 position_args.py   
# python3 position_args.py 10   
# python3 position_args.py 10 bob   

33-函数应用-斐波那契数列

def gen_fib(l):       
fib = [0, 1]             
for i in range(l - len(fib)):           fib.append(fib[-1] + fib[-2])            
return fib  # 返回列表,不返回变量 fib        
a = gen_fib(10)   
print(a)   
print('-' * 50)   
n = int(input("length: "))  
print(gen_fib(n))  # 不会把变量 n 传入,是把 n 代表的值赋值给形参   

34-函数-拷贝文件

import sys         
def copy(src_fname, dst_fname):       
src_fobj = open(src_fname, 'rb')       
dst_fobj = open(dst_fname, 'wb')             
while True:           
data = src_fobj.read(4096)           
if not data:               
break          
dst_fobj.write(data)             
src_fobj.close()       
dst_fobj.close()         
copy(sys.argv[1], sys.argv[2])   
# 执行方式   
# cp_func.py /etc/hosts /tmp/zhuji.txt   

35-函数-九九乘法表

def mtable(n):       
for i in range(1, n + 1):           
for j in range(1, i + 1):               
print('%s*%s=%s' % (j, i, i * j), end=' ')           print()         
mtable(6)   
mtable(9)   

36-模块基础

每一个以 py 作为扩展名的文件都是一个模块。

star.py:   
hi = 'hello world!'         
def pstar(n=50):       
print('*' * n)         
if __name__ == '__main__':       
pstar()       
pstar(30)   

在 call_star.py 中调用 star 模块:

import star         
print(star.hi)   
star.pstar()   
star.pstar(30)   

37-生成密码/验证码

此文件名为:randpass.py

思路:

1、设置一个用于随机取出字符的基础字符串,本例使用大小写字母加数字

2、循环 n 次,每次随机取出一个字符

3、将各个字符拼接起来,保存到变量 result 中

from random import choice   
import string         

all_chs = string.ascii_letters + string.digits  # 大小写字母加数字       
  
def gen_pass(n=8):       
result = '' 
            
for i in range(n):           
ch = choice(all_chs)           
result += ch      
       
return result       
  
if __name__ == '__main__':       
print(gen_pass())       
print(gen_pass(4))       
print(gen_pass(10))   

38-序列对象方法

from random import randint         

alist = list()  # []   
list('hello')  # ['h', 'e', 'l', 'l', 'o']   
list((10, 20, 30))  # [10, 20, 30]  元组转列表   
astr = str()  # ''   
str(10)  # '10'   
str(['h', 'e', 'l', 'l', 'o'])  # 将列表转成字符串   
atuple = tuple()  # ()   
tuple('hello')  # ('h', 'e', 'l', 'l', 'o')   
num_list = [randint(1, 100) 
for i in range(10)]  
max(num_list)   
min(num_list)   

39-序列对象方法 2

alist = [10, 'john']   # list(enumerate(alist))  # [(0, 10), (1, 'john')]   # a, b = 0, 10   # a->0  ->10  

       
for ind in range(len(alist)):       
print('%s: %s' % (ind, alist[ind]))     
    
for item in enumerate(alist):       
print('%s: %s' % (item[0], item[1]))    
     
for ind, val in enumerate(alist):       
print('%s: %s' % (ind, val))       
  
atuple = (96, 97, 40, 75, 58, 34, 69, 29, 66, 90)   
sorted(atuple)   
sorted('hello')   
for i in reversed(atuple):       
print(i, end=',')   

40-字符串方法

py_str = 'hello world!'  
py_str.capitalize()  
py_str.title()  
py_str.center(50)  
py_str.center(50, '#')  
py_str.ljust(50, '*')  
py_str.rjust(50, '*')  
py_str.count('l')  # 统计 l 出现的次数  
py_str.count('lo')  
py_str.endswith('!')  # 以!结尾吗?  
py_str.endswith('d!')  
py_str.startswith('a')  # 以 a 开头吗?  
py_str.islower()  # 字母都是小写的?其他字符不考虑  
py_str.isupper()  # 字母都是大写的?其他字符不考虑  
'Hao123'.isdigit()  # 所有字符都是数字吗?  
'Hao123'.isalnum()  # 所有字符都是字母数字?  
'  hello\t    '.strip()  # 去除两端空白字符,常用  
'  hello\t    '.lstrip()  
'  hello\t    '.rstrip()  
'how are you?'.split()  
'hello.tar.gz'.split('.')  
'.'.join(['hello', 'tar', 'gz'])  
'-'.join(['hello', 'tar', 'gz'])

最后这里免费分享给大家一份Python学习资料,包含视频、源码。课件,希望能帮到那些不满现状,想提升自己却又没有方向的朋友,也可以和我一起来学习交流呀。
编程资料、学习路线图、源代码、软件安装包等!【点击这里】领取!
Python所有方向的学习路线图,清楚各个方向要学什么东西
100多节Python课程视频,涵盖必备基础、爬虫和数据分析
100多个Python实战案例,学习不再是只会理论
华为出品独家Python漫画教程,手机也能学习
历年互联网企业Python面试真题,复习时非常方便

- End -

猜你喜欢

转载自blog.csdn.net/2301_78217634/article/details/131735791