实验8:模块

一、实验目的和要求

1、了解模块的内容;

2、掌握模块的创建和导入方式

3、了解包结构的创建和使用

 

二、实验环境

软件版本:Python 3.10 64_bit

 

三、实验过程

1、实例01:创建计算BMI指数的模块

(1)在IDLE中创建一个名称为weathereport.py的文件,然后在该文件中应用字符串的format()方法格式化输出实时天气预报,代码如下:

 1 def fun_bmi(person,height,weight):
 2     '''功能:根据身高和体重计算BMI指数
 3         person:姓名
 4         height:身高,单位:米
 5         weight:体重,单位:千克
 6     '''
 7 
 8     print(person + "的身高:" + str(height) + "米\t体重:" + str(weight) + "千克")
 9     bmi=weight/(height*height)                  # 用于计算BMI指数,公式为:BMI=体重/身高的平方
10     print(person + "的BMI指数为:"+str(bmi))      # 输出BMI指数
11     # 此处省略了显示判断结果的代码
12 def fun_bmi_upgrade(*person):
13     '''功能:根据身高和体重计算BMI指数(升级版)
14         *person:可变参数该参数中需要传递带3个元素的列表,
15         分别为姓名、身高(单位:米)和体重(单位:千克)
16     '''
17 
18     # 此处省略了函数主体代码

 

2、实例02:导入两个包括同名函数的模块

(1)创建两个模块,一个是矩形模块,其中包括计算矩形周长和面积的函数;另一个是圆形,其中包括计算圆形周长和面积的函数。然后在另一个Python文件中导入这两个模块,并调用相应的函数计算周长的面积。具体步骤如下:

 

1.创建矩形模块,对应的文件名为rectangle.py,在该文件中定义两个函数,一个用于计算矩形的周长,另一个用于计算矩形的面积,代码如下:

 1 def girth(width,height):
 2     '''功能:计算周长
 3         参数:width(宽度)、height(高)
 4     '''
 5     return(width + height)*2
 6 def area(width,height):
 7     '''功能:计算面积
 8         参数:width(宽度)、height(高)
 9     '''
10     return width * height
11 if __name__ == '__main__':
12     print(area(10,20))

 

2.创建圆形模块,对应的文件名称为circular.py,在该文件中定义两个函数,一个用于计算圆形的周长,另一个用于计算圆形的面积,代码如下:

 

 

 

 1 import math                         # 导入标志模块math
 2 PI = math.pi                        # 圆周率
 3 def girth(r):
 4     '''功能:计算周长
 5         参数:r(半径)
 6     '''
 7     return round(2 * PI * r ,2 )    # 计算周长并保留两位小数
 8 def area(r):
 9     '''功能:计算面积
10         参数:r(半径)
11     '''
12     return round(PI * r * r ,2 )    # 计算面积并保留两位小数
13 if __name__ == '__main__':
14     print(girth(10))

3.创建一个名称为compute.py 的Python文件,首先导入矩形模块的全部定义,然后导入圆形模型的全部定义,最后分别调用计算矩形周长的函数和计算圆形周长的函数,代码如下:

1 from rectangle import *                    # 导入矩形模块
2 from circular import *                     # 导入圆形模块
3 if __name__ == '__main__':
4     print('圆形的周长为:',girth(10))        # 调用计算圆形周长的函数
5     print('矩形的周长为:',girth(10,20))     # 调用计算矩形周长的函数

 

执行compute.py文件,结果如下:

从图中可以看出执行步骤(3)的第5行代码时出现异常,这是因为原本想执行的矩形模块的girth() 函数被圆形模块的girth() 函数给盖住了。解决该问题的方法是,不使用from...import 语句导入,而是使用import 语句导入。修改后的代码如下:

1 import rectangle as r                          # 导入矩形模块
2 import circular as c                           # 导入圆形模块
3 if __name__ == '__main__':
4     print('圆形的周长为:',c.girth(10))        # 调用计算圆形周长的函数
5     print('矩形的周长为:',r.girth(10,20))     # 调用计算矩形周长的函数

 

 

(2)运行结果如下:

 

 

 

3、实例03:在制定包中创建通用的设置和获取尺寸的模块

(1)在IDLE中创建一个名称为weathereport.py的文件,然后在该文件中应用字符串的format()方法格式化输出实时天气预报,在settings包中,创建一个名称为size的模块,在该模块中,定义两个保护类型的的全局变量,分别代表宽度和高度,然后定义一个change()函数,用于修改两个全局变量的值,在定义两个函数,分别用于获取宽度和高度,代码如下

 1 width = 800             # 定义保护类型的全局变量(宽度)
 2 height = 600            # 定义保护类型的全局变量(高度)
 3 def change(w,h):
 4     global _width      # 全局变量(宽度)
 5     _width = w          # 重新给宽度赋值
 6     global _height     # 全局变量(高度)
 7     _height = h         # 重新给高度赋值
 8 def getWidth():        # 获取宽度的函数
 9     global _width
10     return _width
11 def getHeight():       # 获取高度的函数
12     global _height
13     return _height

在settings 包的上一层目录中创建一个名称为main.py的文件,在该文件中导入settings包下的size模块的全部定义,并且调用change()函数重新设置宽度和高度,然后在分别调用getWidth()和getHeight()函数获取修改后的宽度和高度,具体代码如下:

1 from settings.size import *         # 导入size模块下的全部定义
2 if __name__=='__main__':
3     change(1024,768)                # 调用change()函数改变尺寸
4     print('宽度:',getWidth())       # 输出宽度
5     print('高度:',getHeight())      # 输出高度

 

 

 

(2)运行结果如下:

 

 

 

4、实例04:生成由数字、字母组成的4位验证码

(1)在IDLE中创建一个名称为weathereport.py的文件,然后在该文件中应用字符串的format()方法格式化输出实时天气预报,代码如下:

 1 import random                                           # 导入标准模块中的random
 2 if __name__=='__main__':
 3     checkcode = ""                                    # 保存验证码的变量
 4     for i in range(4):                                  # 循环4次
 5         index = random.randrange(0,4) # 生成0~3中的一个数
 6         if index != i and index + 1 != i:
 7             checkcode += chr(random.randint(97,122)) # 生成a~z中的一个小写字母
 8         elif index + 1 == i:
 9             checkcode += chr(random.randint(65,90))  # 生成A~Z中的一个大写字母
10         else:
11             checkcode += str(random.randint(1,9))    # 生成1~9中的一个数字
12     print("验证码:",checkcode)                         # 输出生成的验证码

 

(2)运行结果如下:

 

 

 

5、实战01:大乐透号码生成器

(1)在IDLE中创建一个名称为weathereport.py的文件,然后在该文件中应用字符串的format()方法格式化输出实时天气预报,代码如下:

 1 import random
 2 def GreatLotto(times):
 3     Greatnumber = []
 4     for i in range(0,times):
 5         numbers = []
 6         leftlist = list(range(1,36))
 7         leftnumber = random.sample(leftlist,5)
 8         rightlist = list(range(1,13))
 9         rightnumber = random.sample(rightlist,2)
10         leftnumber.sort()
11         rightnumber.sort()
12         numbers = leftnumber + rightnumber
13         for n in range(len(numbers)):
14             if numbers[n]<10:
15                 numbers[n] = '0'+ str(numbers[n])
16         Greatnumber.append( numbers)
17     return Greatnumber

 

引用模块的代码如下:

1 import sz1_1
2 print("大乐透生成器")
3 time = input("请输入要随即大乐透号码注数:")
4 Greatnumber = sz1_1.GreatLotto(int(time))
5 for i in range(0,int(time)):
6     print('{} {} {} {} {}     {} {}'.format(Greatnumber[i][0],Greatnumber[i][1],
7                                             Greatnumber[i][2],Greatnumber[i][3],
8                                             Greatnumber[i][4],Greatnumber[i][5],
9                                             Greatnumber[i][6]))

 

 

 

(2)运行结果如下:

 

 

 

6、实战02:春节集五福

(1)在IDLE中创建一个名称为weathereport.py的文件,然后在该文件中应用字符串的format()方法格式化输出实时天气预报,代码如下:

 1 import  random
 2 def Ji_Fu():
 3     fus=['爱国福','富强福','和谐福','友善福','敬业福']
 4     fu = random.sample(fus,1)
 5     return fu
 6 def fus(fu):
 7     print('当前拥有的福:')
 8     for i, j in fu.items():
 9         print(i,': ',j,'\t',end='')
10 def five_blessings(fu):
11     type=1
12     for i, j in fu.items():
13         if j==0:
14           type=0
15     return type;

引用模块的代码如下:

 1 import sz2_1
 2 print('开始集福啦~~~')
 3 fu={'爱国福':0,'富强福':0,'和谐福':0,'友善福':0,'敬业福':0}
 4 while  sz2_1.five_blessings(fu)==0:
 5     input('\n按下<Enter>键获取五福')
 6     Strfu=sz2_1.Ji_Fu()[0]
 7     print('获取到:' + Strfu)
 8     fu[Strfu] += 1
 9     sz2_1.fus(fu)
10 print('\n恭喜您集成五福!!!')

 

(2)运行结果如下:

 

 

7、实战03:封装用户的上网行为

(1)在IDLE中创建一个名称为weathereport.py的文件,然后在该文件中应用字符串的format()方法格式化输出实时天气预报,代码如下:

 1 def net_play(time):
 2   print("浏览网页",str(time) + "小时")
 3   return time
 4 def Watch_videos(time):
 5     print("看视频",str(time) + "小时")
 6     return time
 7 def Play_game(time):
 8     print("玩网络游戏",str(time) + "小时")
 9     return time
10 def Study(time):
11     print( "上网学习",str(time) + "小时")
12     return time
13 def times(time):
14     if time >= 8:
15        print("今天上网时间共计" + str(time) + "小时,请保护眼睛,合理安排上网时间!")
16     return time

引用模块的代码如下:

1 import sz3_1
2 name = "小明"
3 time = 0;
4 print(name,"上网时间、行为统计:")
5 time += sz3_1.net_play(1.5)
6 time += sz3_1.Watch_videos(2)
7 time += sz3_1.Play_game(3)
8 time += sz3_1.Study(2)
9 sz3_1.times(time)

 

 

 

(2)运行结果如下:

 

 

 

8、实战04:计算个人所得税

(1)在IDLE中创建一个名称为weathereport.py的文件,然后在该文件中应用字符串的format()方法格式化输出实时天气预报,代码如下:

 1 def my_tax(z):
 2     if z <= 0:
 3         print("NULL")
 4     else:
 5         if z <= 1500:
 6             t = z * 0.03
 7         elif z <= 4500:
 8             t = z * 0.1 - 105
 9         elif z <= 9000:
10             t = z * 0.2 - 555
11         elif z <= 35000:
12             t = z * 0.25 -1005
13         elif z <= 55000:
14             t = z * 0.3 -2755
15         elif z <= 80000:
16             t = z * 0.35 - 5505
17         else:
18             t = z * 0.45 - 13505
19     tt = "{:.2f}".format(t)
20     print(tt)

引用模块的代码如下:

1 import sz4_1
2 salary = float(input("请输入月收入:"))
3 if salary>=7662:
4     money = salary - 7662 * 0.225
5 else:
6     money = salary * 0.775
7 z = money - 3500
8 print("应纳个人所得税税额为",end = "")
9 sz4_1.my_tax(z)

 

 

 

(2)运行结果如下:

 

 

posted on 2022-12-28 10:19  Mandeluda  阅读(183)  评论(0编辑  收藏  举报