Python实现拣货员拣货的时间长短分析,你偷没偷懒我不看都知道!

2023-10-29 17:59

本文主要是介绍Python实现拣货员拣货的时间长短分析,你偷没偷懒我不看都知道!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、需求的描述

在这里插入图片描述

å¨è¿éæå¥å¾çæè¿°

å¨è¿éæå¥å¾çæè¿°

å¨è¿éæå¥å¾çæè¿°

å¨è¿éæå¥å¾çæè¿°

另外,这里还有一个堵塞的情况;

在这里插入图片描述


 

最后,一些参数如下所示:
在这里插入图片描述

二、我们对于需求的分析

对于一个问题,首先应该分析清楚他是要我们做什么的!!

首先,我们应该定义一个类(员工类),然后,每一个员工就是对应于一个类的实例对象了啦。也就是说,我们这里需要定义30个实例对象的。

接着,我们在员工类里面给对象设置一些属性,比如说:1、开始工作的时间;2、需要到达的位置,还有需要拣出来多少货物;3、等待(堵塞)了多长的时间。 等等

然后,在类里面实现一些函数,比如:1、计算行走的时间;2、计算拣货的时间;3、计算堵塞的时间;4、打印员工的相关拣货信息;5、计算一个员工总共的耗时时间。 等等

最后,在 main 函数中执行代码计算最终的结果。

在这里需要强调一下:1、每一个员工的信息(拣货的信息)需要用户进行输入进去的;2、注意每个员工都有可能会遇到堵塞的情况;3、一个员工工作的总时间为 行走时间 + 拣货时间 + 堵塞时间。

然后呢,我们写一个文件来定义员工类,

接着写一个文件来实现时间的计算,

然后,在主函数之中调用实现时间的计算的文件来进行实现功能。

三、员工类的实现

直接上代码,因为,我在代码里面写了十分详细地注释,相信大家是可以看懂得啦。(看代码里面的注释一定是可以理解的)
员工类的实现的源代码:

 

# 自定义一个模块,这个文件中定义一个员工类,每一个员工都是该类的一个实例对象class Employee(object):"""员工类"""def __init__(self, start_time, goods_message, taboo_table, speed=0.9, choose=1, wait_time=0):"""初始化一个实例对象:param start_time: 员工开始出发的时间:param goods_message: 员工需要达到的货架以及所需要取多少货品:param taboo_table: 禁忌表,记录每个员工何时在哪一个通道内部,何时进入、出去,刚开始,禁忌表为空,后面利用函数进行添加:param speed: 恒定的行走速度,0.9:param choose: 恒定值,挑选商品,1:param wait_time: 等待的时间,即就是堵塞的时间,先赋值为 0 ,后续再更改"""self.start_time = start_time  # 开始出发的时间self.goods_message = goods_message  # 需要达到的货架以及所需要取多少货品"""一个商品信息应该如下:[(x, r, y), goods_number]然后多个类似的列表会组成一个总的商品列表"""self.taboo_table = taboo_table  # 禁忌表,记录何时在哪一个通道内部,何时进入、出去self.speed = speedself.choose = chooseself.time_of_walk_and_choose = 0  # 先赋值为 0 ,后续再更改self.wait_time = wait_time  # 堵塞的时间,先赋值为 0 ,后续再更改self.the_total_of_the_time = 0  # 总的时间(包含了行走、等待或者说堵塞、拣货这三个时间),先赋值为 0 ,后续再更改self.time_of_walk = 0  # 走的总时间,先赋值为 0 ,后续再更改self.time_of_choose = 0  # 拣货的总时间,先赋值为 0 ,后续再更改def compute_walk_and_choose_time(self):"""计算行走以及取货物的时间,此时尚未考虑堵塞的问题,将在后续的函数考虑:return: 空"""x_list = []y_list = []for i in self.goods_message:x_list.append(i[0][0])# 获取到所有的要去的通道的编号for j in self.goods_message:if j[0][0] == max(x_list):  # 如果是在最后一个通道内的货架y_list.append(j[0][2])# 获取到最后一个通道内部的 y 坐标y = max(y_list)# 求出最后一个通道所需要达到的最远的 y 坐标if len(self.goods_message) % 2 == 0:# 如果商品信息的列表的长度是偶数,即就是说去偶数个货架distance = (max(x_list) - 1) * 3.2 + 1 + 20 * len(x_list)# d = (max(x) - 1) * 3.2 + 1 + 20 * n, n 为偶数else:distance = (max(x_list) - 1) * 3.2 + 1 + 20 * (len(x_list) - 1) + 1.2 * y# d = (max(x) - 1) * 3.2 + 1 + 20 * (n - 1) + 1.2 * y, n 为奇数time1 = distance / self.speed  # 计算行走的时间sum_goods_number = 0for k in self.goods_message:sum_goods_number += k[1]time2 = sum_goods_number * self.choose  # 挑拣商品的时间time_of_walk_and_choose = time1 + time2self.time_of_walk_and_choose = time_of_walk_and_choose# 将这个时间赋值给对象的属性记录下来self.time_of_walk = time1self.time_of_choose = time2# 分别记录下行走的时间以及拣货的时间def make_the_taboo_table(self):"""生成禁忌表,记录每个员工何时在哪一个通道内部,何时进入、出去:return: 空"""x_list = []for i in self.goods_message:x_list.append(i[0][0])# 获取到所有的要去的通道的编号x_list.sort()  # 从小到大排序if len(x_list) % 2 == 0:# 偶数个通道record_number = 0t1 = self.start_time  # 最开始初始化为开始的时间for n in range(len(x_list)):# 循环所有的通道if n == 0:# 员工第一个进入的通道dt1 = (1 + (x_list[n] - 1) * 3.2) / self.speed# 走到通道的入口需要的时间else:# 不是员工第一个进入的通道dt1 = ((x_list[n] - x_list[n - 1]) * 3.2) / self.speed# 走到通道的入口需要的时间sum_of_goods = 0for m in self.goods_message:# 循环所有的货架if m[0][0] == x_list[record_number]:sum_of_goods += m[1]dt2 = (sum_of_goods * self.choose) + (20 / self.speed)  # 变化了的时间# 包含了 拣货 + 行走self.taboo_table[f'{x_list[record_number]}'] = [t1 + dt1, t1 + dt1 + dt2]# 进入时间为:初始时间 + 走到入口# 出去时间为:初始时间 + 走到入口 + 在通道内部的时间t1 = t1 + dt1 + dt2  # 重新对 t1 进行赋值record_number += 1  # 记录数字自加一else:# 通道个数为奇数record_number = 0t1 = self.start_time  # 最开始初始化为开始的时间# 这里初始化为最开始的时间for n in range(len(x_list) - 1):  # 最后一个需要单独处理啦# 循环所有的通道if n == 0:# 员工第一个进入的通道dt1 = (1 + (x_list[n] - 1) * 3.2) / self.speed# 走到通道的入口需要的时间else:# 不是员工第一个进入的通道dt1 = ((x_list[n] - x_list[n - 1]) * 3.2) / self.speed# 走到通道的入口需要的时间sum_of_goods = 0for m in self.goods_message:# 循环所有的货架if m[0][0] == x_list[record_number]:sum_of_goods += m[1]dt2 = (sum_of_goods * self.choose) + (20 / self.speed)  # 变化了的时间# 包含了 拣货 + 行走self.taboo_table[f'{x_list[record_number]}'] = [t1 + dt1, t1 + dt1 + dt2]# 进入时间为:初始时间 + 走到入口# 出去时间为:初始时间 + 走到入口 + 在通道内部的时间t1 = t1 + dt1 + dt2  # 重新对 t1 进行赋值record_number += 1# 记录数字自加一continuey_list = []for j in self.goods_message:if j[0][0] == max(x_list):  # 如果是在最后一个通道内的货架y_list.append(j[0][2])# 获取到最后一个通道内部的 y 坐标y = max(y_list)# 求出最后一个通道所需要达到的最远的 y 坐标last_sum_of_goods1 = 0for m in self.goods_message:# 循环所有的货架if m[0][0] == x_list[record_number]:last_sum_of_goods1 += m[1]self.taboo_table[f'{x_list[len(x_list) - 1]}'] = [t1 + ((x_list[len(x_list) - 1] - x_list[len(x_list) - 1 - 1]) * 3.2) / self.speed, t1 + ((x_list[len(x_list) - 1] - x_list[len(x_list) - 1 - 1]) * 3.2) / self.speed + last_sum_of_goods1 * self.choose + (1.2 * y) / self.speed]def compute_the_total_of_the_time(self):"""计算一个员工所需要的总的时间:return: 空"""self.the_total_of_the_time = self.time_of_walk_and_choose + self.wait_time# 总时间 = 行走以及拣货的时间 + 等待(堵塞)的时间def __str__(self):"""定义一个函数来打印相关对象的信息:return: 空"""print("该员工处理的订单信息为:", end='\n')j = 1for message in self.goods_message:print(f'第 {j} 个货物,坐标位置: {message[0]},取货数目: {message[1]}')j += 1# j 自加一print()str0 = f"该员工的工作总时间为:{self.the_total_of_the_time}," \f"行走的时间为:{self.time_of_walk}," \f"拣货的时间为:{self.time_of_choose}," \f"堵塞的时间为:{self.wait_time}."return str0

四、计算时间的源代码

这里还是一样的啊,我们直接给出来源代码,因为里面也是有很多的详细地注释来进行解释代码的啦
源代码:

 

# 导入模块from employee_package.employee import Employeedef execute_the_code():"""运行程序,进行员工拣货的模拟实现,首先实现每一个员工的初始化操作,然后,实现每一个员工的工作时间的计算:return: 空"""# 员工的人数q = 3# 生成员工列表并进行初始化employ_list = []# 初始化员工的信息for i in range(q):"""初始化"""input_goods_message = []# 请用户输入商品的货架信息while True:print(f"请输入第 {i + 1} 个员工的初始化信息,即就是第 {i + 1} 个员工对应的订单信息")x = int(input('输入 x 坐标 :'))# 转换为 inty = int(input('输入 y 坐标 :'))  # 转换为 intr = int(input('输入 r 坐标 :'))  # 转换为 intnumber = int(input('输入该货架中要取出来多少货物 :'))  # 转换为 intinput_goods_message.append([(x, r, y), number])# [(x, r, y), goods_number]break_or_not = input('如果输入完毕了,请输入 1 来结束操作 !\n 如果要继续输入请直接回车!')if break_or_not == '1':breakelse:continue# 定义一个中间变量作为新的员工new_employee = Employee(start_time=20 * i,goods_message=input_goods_message,taboo_table={})# 加入新的员工到列表之中去employ_list.append(new_employee)# 计算每一个员工除了堵塞意外所用的时间for i in range(q):"""除了堵塞以外的时间"""employ_list[i].compute_walk_and_choose_time()# 计算除了堵塞意外所用的时间# 生成每一个员工的禁忌表for i in range(q):"""生成禁忌表"""employ_list[i].make_the_taboo_table()# 生成每一个员工的禁忌表# # 打印每一个员工的禁忌表# for i in range(q):#     """#     打印禁忌表#     """#     print(employ_list[i].taboo_table)#     # 打印每一个员工的禁忌表# 计算每一个员工的等待(堵塞)的时间for i in range(q):"""计算堵塞的时间"""# 对任意一个员工都是要进行计算出来延迟的时间的new_dict = {}for j in range(q):# 将每一个非该对象的字典都加入到新的空字典中去if j != i:  # 只要不是当前的对象for data in employ_list[j].taboo_table.keys():# 这里的 data 是一个键if data in new_dict.keys():# 如果已经有了这个键 keynew_dict[data].append(employ_list[j].taboo_table[data])# 加入的是一个列表else:# 如果还没有这个键 keynew_dict[data] = [employ_list[j].taboo_table[data]]# 添加除了当前员工以外的所有的员工的禁忌表到一个字典中方便计算当前员工的堵塞时间# 这一步相当于是将其他人的禁忌表整合在了一起for a_key in employ_list[i].taboo_table.keys():# 遍历当前员工的所有的键,employ_list[i].taboo_table.keys()if a_key in new_dict.keys():# 如果当前员工的键在刚刚生成的字典的键中,那么就需要判断是否会发生堵塞for time in new_dict[a_key]:  # 这里读取到的是一个列表,因此需要遍历列表中的每一个元素if (employ_list[i].taboo_table[a_key][0] >= time[0]) and (employ_list[i].taboo_table[a_key][0] < time[1]):# 如果当前对象进入该通道的时间与其他的对象发生了冲突,那么,我们就需要记录此时的等待时间,也就是说记录堵塞的时间# 这里的情况如果满足,那就是发生了冲突的employ_list[i].wait_time += time[1] - employ_list[i].taboo_table[a_key][0]# 将等待的时间加入到每一个员工的等待时间中去,# 加上一个时间差else:# 如果没有冲突employ_list[i].wait_time += 0else:# 如果当前员工的键不在刚刚生成的字典的键中,那么无论如何都是可以直接前去拣货的啦employ_list[i].wait_time += 0  # 加 0# 这一步是进行计算 i 这个员工的堵塞时间# 计算每一个员工所需要的总时间for i in range(q):"""计算总时间"""employ_list[i].compute_the_total_of_the_time()# 计算每一个员工所需要的总时间# 打印每一个员工的信息for i in range(q):"""输出信息"""print(f"第 {i + 1} 个员工的工作信息如下 : ")print()# 打印拣货信息str00 = employ_list[i].__str__()# 打印时间信息print(str00)  # 打印每一个员工的信息print()

五、main函数的源代码

main函数的源代码:

 

# 导入模块from execute_the_code import executeif __name__ == '__main__':"""main 函数"""# 执行代码, run the codeexecute.execute_the_code()

六、整个程序的源代码:

员工类文件:

 

# 自定义一个模块,这个文件中定义一个员工类,每一个员工都是该类的一个实例对象class Employee(object):"""员工类"""def __init__(self, start_time, goods_message, taboo_table, speed=0.9, choose=1, wait_time=0):"""初始化一个实例对象:param start_time: 员工开始出发的时间:param goods_message: 员工需要达到的货架以及所需要取多少货品:param taboo_table: 禁忌表,记录每个员工何时在哪一个通道内部,何时进入、出去,刚开始,禁忌表为空,后面利用函数进行添加:param speed: 恒定的行走速度,0.9:param choose: 恒定值,挑选商品,1:param wait_time: 等待的时间,即就是堵塞的时间,先赋值为 0 ,后续再更改"""self.start_time = start_time  # 开始出发的时间self.goods_message = goods_message  # 需要达到的货架以及所需要取多少货品"""一个商品信息应该如下:[(x, r, y), goods_number]然后多个类似的列表会组成一个总的商品列表"""self.taboo_table = taboo_table  # 禁忌表,记录何时在哪一个通道内部,何时进入、出去self.speed = speedself.choose = chooseself.time_of_walk_and_choose = 0  # 先赋值为 0 ,后续再更改self.wait_time = wait_time  # 堵塞的时间,先赋值为 0 ,后续再更改self.the_total_of_the_time = 0  # 总的时间(包含了行走、等待或者说堵塞、拣货这三个时间),先赋值为 0 ,后续再更改self.time_of_walk = 0  # 走的总时间,先赋值为 0 ,后续再更改self.time_of_choose = 0  # 拣货的总时间,先赋值为 0 ,后续再更改def compute_walk_and_choose_time(self):"""计算行走以及取货物的时间,此时尚未考虑堵塞的问题,将在后续的函数考虑:return: 空"""x_list = []y_list = []for i in self.goods_message:x_list.append(i[0][0])# 获取到所有的要去的通道的编号for j in self.goods_message:if j[0][0] == max(x_list):  # 如果是在最后一个通道内的货架y_list.append(j[0][2])# 获取到最后一个通道内部的 y 坐标y = max(y_list)# 求出最后一个通道所需要达到的最远的 y 坐标if len(self.goods_message) % 2 == 0:# 如果商品信息的列表的长度是偶数,即就是说去偶数个货架distance = (max(x_list) - 1) * 3.2 + 1 + 20 * len(x_list)# d = (max(x) - 1) * 3.2 + 1 + 20 * n, n 为偶数else:distance = (max(x_list) - 1) * 3.2 + 1 + 20 * (len(x_list) - 1) + 1.2 * y# d = (max(x) - 1) * 3.2 + 1 + 20 * (n - 1) + 1.2 * y, n 为奇数time1 = distance / self.speed  # 计算行走的时间sum_goods_number = 0for k in self.goods_message:sum_goods_number += k[1]time2 = sum_goods_number * self.choose  # 挑拣商品的时间time_of_walk_and_choose = time1 + time2self.time_of_walk_and_choose = time_of_walk_and_choose# 将这个时间赋值给对象的属性记录下来self.time_of_walk = time1self.time_of_choose = time2# 分别记录下行走的时间以及拣货的时间def make_the_taboo_table(self):"""生成禁忌表,记录每个员工何时在哪一个通道内部,何时进入、出去:return: 空"""x_list = []for i in self.goods_message:x_list.append(i[0][0])# 获取到所有的要去的通道的编号x_list.sort()  # 从小到大排序if len(x_list) % 2 == 0:# 偶数个通道record_number = 0t1 = self.start_time  # 最开始初始化为开始的时间for n in range(len(x_list)):# 循环所有的通道if n == 0:# 员工第一个进入的通道dt1 = (1 + (x_list[n] - 1) * 3.2) / self.speed# 走到通道的入口需要的时间else:# 不是员工第一个进入的通道dt1 = ((x_list[n] - x_list[n - 1]) * 3.2) / self.speed# 走到通道的入口需要的时间sum_of_goods = 0for m in self.goods_message:# 循环所有的货架if m[0][0] == x_list[record_number]:sum_of_goods += m[1]dt2 = (sum_of_goods * self.choose) + (20 / self.speed)  # 变化了的时间# 包含了 拣货 + 行走self.taboo_table[f'{x_list[record_number]}'] = [t1 + dt1, t1 + dt1 + dt2]# 进入时间为:初始时间 + 走到入口# 出去时间为:初始时间 + 走到入口 + 在通道内部的时间t1 = t1 + dt1 + dt2  # 重新对 t1 进行赋值record_number += 1  # 记录数字自加一else:# 通道个数为奇数record_number = 0t1 = self.start_time  # 最开始初始化为开始的时间# 这里初始化为最开始的时间for n in range(len(x_list) - 1):  # 最后一个需要单独处理啦# 循环所有的通道if n == 0:# 员工第一个进入的通道dt1 = (1 + (x_list[n] - 1) * 3.2) / self.speed# 走到通道的入口需要的时间else:# 不是员工第一个进入的通道dt1 = ((x_list[n] - x_list[n - 1]) * 3.2) / self.speed# 走到通道的入口需要的时间sum_of_goods = 0for m in self.goods_message:# 循环所有的货架if m[0][0] == x_list[record_number]:sum_of_goods += m[1]dt2 = (sum_of_goods * self.choose) + (20 / self.speed)  # 变化了的时间# 包含了 拣货 + 行走self.taboo_table[f'{x_list[record_number]}'] = [t1 + dt1, t1 + dt1 + dt2]# 进入时间为:初始时间 + 走到入口# 出去时间为:初始时间 + 走到入口 + 在通道内部的时间t1 = t1 + dt1 + dt2  # 重新对 t1 进行赋值record_number += 1# 记录数字自加一continuey_list = []for j in self.goods_message:if j[0][0] == max(x_list):  # 如果是在最后一个通道内的货架y_list.append(j[0][2])# 获取到最后一个通道内部的 y 坐标y = max(y_list)# 求出最后一个通道所需要达到的最远的 y 坐标last_sum_of_goods1 = 0for m in self.goods_message:# 循环所有的货架if m[0][0] == x_list[record_number]:last_sum_of_goods1 += m[1]self.taboo_table[f'{x_list[len(x_list) - 1]}'] = [t1 + ((x_list[len(x_list) - 1] - x_list[len(x_list) - 1 - 1]) * 3.2) / self.speed, t1 + ((x_list[len(x_list) - 1] - x_list[len(x_list) - 1 - 1]) * 3.2) / self.speed + last_sum_of_goods1 * self.choose + (1.2 * y) / self.speed]def compute_the_total_of_the_time(self):"""计算一个员工所需要的总的时间:return: 空"""self.the_total_of_the_time = self.time_of_walk_and_choose + self.wait_time# 总时间 = 行走以及拣货的时间 + 等待(堵塞)的时间def __str__(self):"""定义一个函数来打印相关对象的信息:return: 空"""print("该员工处理的订单信息为:", end='\n')j = 1for message in self.goods_message:print(f'第 {j} 个货物,坐标位置: {message[0]},取货数目: {message[1]}')j += 1# j 自加一print()str0 = f"该员工的工作总时间为:{self.the_total_of_the_time}," \f"行走的时间为:{self.time_of_walk}," \f"拣货的时间为:{self.time_of_choose}," \f"堵塞的时间为:{self.wait_time}."return str0

计算时间的文件:

 

# 导入模块from employee_package.employee import Employeedef execute_the_code():"""运行程序,进行员工拣货的模拟实现,首先实现每一个员工的初始化操作,然后,实现每一个员工的工作时间的计算:return: 空"""# 员工的人数q = 3# 生成员工列表并进行初始化employ_list = []# 初始化员工的信息for i in range(q):"""初始化"""input_goods_message = []# 请用户输入商品的货架信息while True:print(f"请输入第 {i + 1} 个员工的初始化信息,即就是第 {i + 1} 个员工对应的订单信息")x = int(input('输入 x 坐标 :'))# 转换为 inty = int(input('输入 y 坐标 :'))  # 转换为 intr = int(input('输入 r 坐标 :'))  # 转换为 intnumber = int(input('输入该货架中要取出来多少货物 :'))  # 转换为 intinput_goods_message.append([(x, r, y), number])# [(x, r, y), goods_number]break_or_not = input('如果输入完毕了,请输入 1 来结束操作 !\n 如果要继续输入请直接回车!')if break_or_not == '1':breakelse:continue# 定义一个中间变量作为新的员工new_employee = Employee(start_time=20 * i,goods_message=input_goods_message,taboo_table={})# 加入新的员工到列表之中去employ_list.append(new_employee)# 计算每一个员工除了堵塞意外所用的时间for i in range(q):"""除了堵塞以外的时间"""employ_list[i].compute_walk_and_choose_time()# 计算除了堵塞意外所用的时间# 生成每一个员工的禁忌表for i in range(q):"""生成禁忌表"""employ_list[i].make_the_taboo_table()# 生成每一个员工的禁忌表# # 打印每一个员工的禁忌表# for i in range(q):#     """#     打印禁忌表#     """#     print(employ_list[i].taboo_table)#     # 打印每一个员工的禁忌表# 计算每一个员工的等待(堵塞)的时间for i in range(q):"""计算堵塞的时间"""# 对任意一个员工都是要进行计算出来延迟的时间的new_dict = {}for j in range(q):# 将每一个非该对象的字典都加入到新的空字典中去if j != i:  # 只要不是当前的对象for data in employ_list[j].taboo_table.keys():# 这里的 data 是一个键if data in new_dict.keys():# 如果已经有了这个键 keynew_dict[data].append(employ_list[j].taboo_table[data])# 加入的是一个列表else:# 如果还没有这个键 keynew_dict[data] = [employ_list[j].taboo_table[data]]# 添加除了当前员工以外的所有的员工的禁忌表到一个字典中方便计算当前员工的堵塞时间# 这一步相当于是将其他人的禁忌表整合在了一起for a_key in employ_list[i].taboo_table.keys():# 遍历当前员工的所有的键,employ_list[i].taboo_table.keys()if a_key in new_dict.keys():# 如果当前员工的键在刚刚生成的字典的键中,那么就需要判断是否会发生堵塞for time in new_dict[a_key]:  # 这里读取到的是一个列表,因此需要遍历列表中的每一个元素if (employ_list[i].taboo_table[a_key][0] >= time[0]) and (employ_list[i].taboo_table[a_key][0] < time[1]):# 如果当前对象进入该通道的时间与其他的对象发生了冲突,那么,我们就需要记录此时的等待时间,也就是说记录堵塞的时间# 这里的情况如果满足,那就是发生了冲突的employ_list[i].wait_time += time[1] - employ_list[i].taboo_table[a_key][0]# 将等待的时间加入到每一个员工的等待时间中去,# 加上一个时间差else:# 如果没有冲突employ_list[i].wait_time += 0else:# 如果当前员工的键不在刚刚生成的字典的键中,那么无论如何都是可以直接前去拣货的啦employ_list[i].wait_time += 0  # 加 0# 这一步是进行计算 i 这个员工的堵塞时间# 计算每一个员工所需要的总时间for i in range(q):"""计算总时间"""employ_list[i].compute_the_total_of_the_time()# 计算每一个员工所需要的总时间# 打印每一个员工的信息for i in range(q):"""输出信息"""print(f"第 {i + 1} 个员工的工作信息如下 : ")print()# 打印拣货信息str00 = employ_list[i].__str__()# 打印时间信息print(str00)  # 打印每一个员工的信息print()

main函数文件:

 

# 导入模块from execute_the_code import executeif __name__ == '__main__':"""main 函数"""# 执行代码, run the codeexecute.execute_the_code()

综上,这就是我写的一个计算拣货员拣货时间的一个代码啦。

具体的代码呢,我已经上传到了我的资源里面啦,有兴趣的可以下载下来看一看啦。

最后感谢大家阅读了啦。

近期有很多朋友通过私信咨询有关Python学习问题。为便于交流,点击蓝色自己加入讨论解答资源基地

 

这篇关于Python实现拣货员拣货的时间长短分析,你偷没偷懒我不看都知道!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/302379

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount