本文实例为大家分享了python实现停车场管理系统的具体代码,供大家参考,具体内容如下

一、需求

1、为一个车位数量固定的停车场,设计一个管理系统;
2、停车信息包括:编号、车牌号(若存在)、类型、车位编号、使用日期、入场时间、单价、费用、经手人
3、停车信息存储在数据文件中,程序至少实现功能:浏览、查询、入场、出场、导出、计费、系统菜单
4、按面向对象程序设计方法进行类的定义:选择合适的数据存储结构,并定义相应的数据元素类,选择合理的操作方法定义相应的算法实现类

二、代码

本系统包含4部分(4个py文件,剩余为测试数据文件),组成放在一个文件夹组成一个模块,如下图。

2.1 初始化模块__init__.py

"""
__init__.py 模块的作用:在导入包的时候自动执行这里的代码,进行初始化工作
"""
# 允许被 from package_name import * 导入的模块
__all__ = ['ParkingManagementSystem', 'Car']

2.2 主程序模块main.py

# coding = utf-8

from ParkingManagementSystem import *
from Car import *


def main():
    # 创建停车信息管理系统对象
    p = ParkingManagementSystem()
    # 创建一个停车对象
    car = Car()
    while True:
        print("")
        print("******************* 欢迎进入:停车场信息管理系统 *******************")
        print("------------------------- 1.浏览所有信息 ------------------------")
        print("------------------------- 2.查询车辆信息 ------------------------")
        print("------------------------- 3.入场车辆录入 ------------------------")
        print("------------------------- 4.出场车辆删除 ------------------------")
        print("------------------------- 5.退出管理系统 ------------------------")
        try:
            # 接收输入指令
            cmd = int(input("请输入指令数字:"))
            # 1.浏览所有信息
            if cmd == 1:
                p.show_all_information()
            # 2.查询车辆信息
            elif cmd == 2:
                while True:
                    print("------ 1.按车牌号查找 ------")
                    print("------ 2.按车类型查找 ------")
                    print("------ 3.按使用日期查找 -----")
                    print("------ 4.按经手人查找 ------")
                    print("------ 5.查询历史记录 ------")
                    print("------ 6.返回上级菜单 ------")
                    query = int(input("请输入指令数字:"))
                    # 1.按车牌号查找
                    if query == 1:
                        query_results = p.query_by_car_number()
                        # 判定查询结果是否为空(False),是则不保存
                        if query_results:
                            decide = input("是否需要保存查询结果(输入:yes/no):")
                            if decide == "yes":
                                p.save_query_results_to_file(query_results)
                    # 2.按车类型查找
                    elif query == 2:
                        query_results = p.query_by_car_type()
                        # 判定查询结果是否为空(False),是则不保存
                        if query_results:
                            decide = input("是否需要保存查询结果(输入:yes/no):")
                            if decide == "yes":

                                p.save_query_results_to_file(query_results)
                    # 3.按使用日期查找
                    elif query == 3:
                        query_results = p.query_by_date()
                        # 判定查询结果是否为空(False),是则不保存
                        if query_results:
                            decide = input("是否需要保存查询结果(输入:yes/no):")
                            if decide == "yes":
                                p.save_query_results_to_file(query_results)
                    # 4.按经手人查找
                    elif query == 4:
                        query_results = p.query_by_handler()
                        # 判定查询结果是否为空(False),是则不保存
                        if query_results:
                            decide = input("是否需要保存查询结果(输入:yes/no):")
                            if decide == "yes":
                                p.save_query_results_to_file(query_results)
                    # 5.查询历史记录
                    elif query == 5:
                        p.query_history_results()
                    else:
                        break
            # 3.录入车辆信息
            elif cmd == 3:
                # 接收停车车辆信息
                parking_info = car.get_parking_info()
                p.parking(parking_info)
            # 4.删除车辆信息
            elif cmd == 4:
                p.driving_out()
            # 5.退出管理系统
            else:
                # 保存停车信息的最大编号 id
                car.save_id_to_file()
                print("感谢使用停车场管理系统,再见!")
                break
        except Exception as result:
            # 保存停车信息的最大编号 id
            car.save_id_to_file()
            # 保存停车信息
            p.save_to_file()
            print("感谢使用停车场管理系统,再见!")
            break


if __name__ == "__main__":
    main()

2.3 停车管理模块ParkingManagementSystem.py

# coding = utf-8
# 模块中的__all__属性:可以规定 模块中 from module_name import * 只能够导入的一些类、变量、函数名
__all__ = ['ParkingManagementSystem']
import time


class ParkingManagementSystem(object):
    """算法实现类:停车场信息管理系统"""

    def __init__(self):
        """对停车信息进行初始化"""
        # 测试时使用
        print("ParkingManagementSystem的__init__函数被调用")

        # 车位编号存放列表
        self.car_stall = []
        self.truck_stall = []
        # 所有停车信息存放列表
        self.total_info = []

        # 读取停车场数据
        try:
            with open("parking_data.txt", "r") as file:
                for line in file.readlines():
                    # 将字符串转化为字典,遇到空行时跳过,防止eval()函数转化空行或者空字符时报错
                    try:
                        info_dict = eval(line)
                        self.total_info.append(info_dict)
                        if info_dict["car_type"] == "car":
                            self.car_stall.append(info_dict["p_number"])
                        else:
                            self.truck_stall.append(info_dict["p_number"])
                    except Exception as result:
                        continue
        except Exception as result:
            print("停车信息数据文件不存在!")
        # 测试时使用
        # print(self.car_stall)
        # print(self.truck_stall)
        # print(self.total_info)

    def parking(self, parking_info):
        """入场停车:传入停车信息,在空的车位中增加车辆信息,更新数据文件"""
        # 判断传入停车信息是否为 None
        # 需要完整代码请在文章文章底部添加微信,付费咨询
        passs

    def show_all_information(self):
        """输出所有停车场信息,按车位使用情况分类,同一分类中按编号升序排序"""
        # 初始化刷新数据
        # 需要完整代码请在文章文章底部添加微信,付费咨询
        pass

    def query_by_car_number(self):
        """按车牌号查找停车信息"""
        # 接收车牌编号
        # 需要完整代码请在文章文章底部添加微信,付费咨询
        pass

    def query_by_car_type(self):
        """按车类型查找停车信息"""
        # 接受车类型
        # 需要完整代码请在文章文章底部添加微信,付费咨询
       pass

    def query_by_date(self):
        """按使用日期查找停车信息"""
        # 接收查询日期
        date = input("请输入查询日期(格式参考:1998-06-06):")
        # 创建列表保存查询结果
        # 需要完整代码请在文章文章底部添加微信,付费咨询
       pass

    def query_by_handler(self):
        """按经手人查找停车信息"""
        # 接收经手人姓名
        handler = input("请输入经手人姓名:")
        # 需要完整代码请在文章文章底部添加微信,付费咨询
        pass

    def query_history_results(self):
        """查询停车场历史记录"""
        # 查询输入格式化
        # 需要完整代码请在文章文章底部添加微信,付费咨询
        print("id  car_type  p_number  car_number   handler   price    cost     entrance_time            exit_time")
        

    def driving_out(self):
        """出场:删除对应车位的车辆信息,更新数据文件"""
        # 接收出场时间
        exit_time = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
        # 接收车牌号
        car_number = input("请输入出场车辆车牌号(示例:京A88888):")
        # 遍历总停车信息列表,找到该条数据并将其移除列表
        pass

    def charging(self, info_dict):
        """计费: 传入停车信息,按小时计费"""
        # 接收车辆停车信息
        # 将时间由字符串格式转化为数字格式,以秒为单位
        exit_time = time.mktime(time.strptime(info_dict["exit_time"], "%Y-%m-%d %H:%M:%S"))
        entrance_time = time.mktime(time.strptime(info_dict["entrance_time"], "%Y-%m-%d %H:%M:%S"))
        # 计算停车时间,单位转化为小时
        pass

    def save_to_file(self):
        """将停车数据保存到文件"""
        # 打开数据文件,保存数据
        with open("parking_data.txt", "w") as file:
            for info_dict in self.total_info:
                # 将字典转化为字符串保存
                file.write(str(info_dict))
                file.write("\n")

    def save_history_to_file(self, info_dict):
        """将已完成出场停车数据保存到文件"""
        # 打开数据文件,保存数据
        with open("history_data.txt", "a") as file:
            # 将字典转化为字符串保存
            file.write(str(info_dict))
            file.write("\n")

    def save_query_results_to_file(self, query_results):
        """将查询结果保存到指定数据文件"""
        # 接收输入文件名
        file_name = input("请输入要保存数据的文件名(格式:xxx.txt ):")
        with open(file_name, "a") as file:
            # 将数据转化为字符串保存
            file.write(str(query_results))
            file.write("\n")
        print("查询结果保存成功,文件名为:%s" % file_name)

    def print_func(self, info_dict, query_results):
        """格式化打印输出查询结果"""
        # 需要完整代码请在文章文章底部添加微信,付费咨询
        pass

2.4 车元素模块Car.py

# coding = utf-8
# 模块中的__all__属性:可以规定 模块中 from module_name import * 只能够导入的一些类、变量、函数名
__all__ = ['Car']
import time
from ParkingManagementSystem import *


class Car(ParkingManagementSystem):
    """数据元素类:定义一个关于车的类"""

    def __init__(self):
        """对车的属性进行初始化"""
        # 测试时使用
        print("Car 中__init__调用成功!")
        # 设定初始出场时间和消费金额为空
        self.exit_time = None
        self.cost = None
        # 初始编号 id 为 1
        self.id = 1
        # 读取文件中编号
        try:
            with open("count_id.txt", "r") as file:
                self.id = int(file.read())
        except Exception as result:
            pass
        # 测试时使用
        print(self.id)

    def get_parking_info(self):
        """获取车辆停车信息"""
        # 调用父类中的属性
        ParkingManagementSystem.__init__(self)
        car_type = input("请输入车类型(car 或 truck):")
        # 判断车位是否已满,如已满则提示客户去其他停车场,如未满则分配一个车位给客户
        if car_type == "car":
            # 如车位已满,提醒客户去其他停车场,car类型的车位设定为100个
            if len(self.car_stall) >= 100:
                print("小汽车车位已满,请去其他停车场。")
                return
            # 如还有车位,则分配一个车位给客户
            else:
                # 不同车型不同价位
                price = 10
                # 车位编号为:1-100
                for i in range(100):
                    # 分配空着的车位编号
                    if i   1 not in self.car_stall:
                        p_number = i   1
                        self.car_stall.append(p_number)
                        print(self.car_stall)
                        break
        elif car_type == "truck":
            # 如车位已满,提醒客户去其他停车场,truck类型的车位设定为50个
            if len(self.truck_stall) >= 50:
                print("货车车位已满,请去其他停车场。")
                return
            # 如还有车位,则分配一个车位给客户
            else:
                # 不同车型不同价位
                price = 20
                # 车位编号为:101-150
                for i in range(100, 150):
                    # 分配空着的车位编号
                    if i   1 not in self.truck_stall:
                        p_number = i   1
                        self.truck_stall.append(p_number)
                        print(self.truck_stall)
                        break
        else:
            print("本停车场没有适合该车型的停车位,请重新输入!")
            return
        # 接收车位编号
        car_number = input("请输入车牌号(示例:京A88888):")
        # 接收经手人姓名
        handler = input("请输入经手人姓名:")
        # 接收入场时间
        entrance_time = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
        # 接收使用日期
        date = time.strftime("%Y-%m-%d", time.localtime())
        # 编号 id 自动增长
        self.id  = 1
        # 保存该条停车信息到字典
        parking_info = {
            "id": self.id,
            "car_type": car_type,
            "car_number": car_number,
            "handler": handler,
            "p_number": p_number,
            "date": date,
            "entrance_time": entrance_time,
            "exit_time": self.exit_time,
            "price": price,
            "cost": self.cost
        }
        print(parking_info)
        # 返回车辆停车信息
        return parking_info

    def save_id_to_file(self):
        """保存停车信息的最大编号 id ,作为下次运行id增长的基础"""
        with open("count_id.txt", "w") as file:
            file.write(str(self.id))

三、运行测试

3.1 浏览所有信息

3.2 查询车辆信息

3.2.1 按车牌号查找

3.2.2 按车类型查找

3.2.3 按使用日期查找

3.2.4 按经手人查找

3.2.5 查询历史记录

3.3 入场车辆录入

3.4 出场车辆删除

3.5 退出管理系统

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持Devmax。

python实现停车场管理系统的更多相关文章

  1. XCode 3.2 Ruby和Python模板

    在xcode3.2下,我的ObjectiveCPython/Ruby项目仍然可以打开更新和编译,但是你无法创建新项目.鉴于xcode3.2中缺少ruby和python的所有痕迹(即创建项目并添加新的ruby/python文件),是否有一种简单的方法可以再次安装模板?我发现了一些关于将它们复制到某个文件夹的信息,但我似乎无法让它工作,我怀疑文件夹的位置已经改变为3.2.解决方法3.2中的应用程序模板

  2. Swift基本使用-函数和闭包(三)

    声明函数和其他脚本语言有相似的地方,比较明显的地方是声明函数的关键字swift也出现了Python中的组元,可以通过一个组元返回多个值。传递可变参数,函数以数组的形式获取参数swift中函数可以嵌套,被嵌套的函数可以访问外部函数的变量。可以通过函数的潜逃来重构过长或者太复杂的函数。

  3. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  4. Swift、Go、Julia与R能否挑战 Python 的王者地位

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 红薯因 Swift 重写开源中国失败,貌似欲改用 Python

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  6. 你没看错:Swift可以直接调用Python函数库

    上周Perfect又推出了新一轮服务器端Swift增强函数库:Perfect-Python。对,你没看错,在服务器端Swift其实可以轻松从其他语种的函数库中直接拿来调用,不需要修改任何内容。以如下python脚本为例:Perfect-Python可以用下列方法封装并调用以上函数,您所需要注意的仅仅是其函数名称以及参数。

  7. Swift中的列表解析

    在Swift中完成这个的最简单的方法是什么?我在寻找类似的东西:从Swift2.x开始,有一些与你的Python样式列表解析相当的东西。(在这个意义上,它更像是Python的xrange。如果你想保持集合懒惰一路通过,只是这样说:与Python中的列表解析语法不同,Swift中的这些操作遵循与其他操作相同的语法。

  8. swift抛出终端的python错误

    每当我尝试启动与python相关的swift时,我都会收到错误.我该如何解决?

  9. 在Android上用Java嵌入Python

    解决方法看看this,它适用于J2SE,你可以尝试在Android上运行.

  10. 在android studio中使用python代码构建android应用程序

    我有一些python代码和它的机器人,我正在寻找一种方法来使用android项目中的那些python代码.有没有办法做到这一点!?解决方法有两种主要工具可供使用,它们彼此不同:>QPython>Kivy使用Kivy,大致相同的代码也可以部署到IOS.

随机推荐

  1. 10 个Python中Pip的使用技巧分享

    众所周知,pip 可以安装、更新、卸载 Python 的第三方库,非常方便。本文小编为大家总结了Python中Pip的使用技巧,需要的可以参考一下

  2. python数学建模之三大模型与十大常用算法详情

    这篇文章主要介绍了python数学建模之三大模型与十大常用算法详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感想取得小伙伴可以参考一下

  3. Python爬取奶茶店数据分析哪家最好喝以及性价比

    这篇文章主要介绍了用Python告诉你奶茶哪家最好喝性价比最高,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧

  4. 使用pyinstaller打包.exe文件的详细教程

    PyInstaller是一个跨平台的Python应用打包工具,能够把 Python 脚本及其所在的 Python 解释器打包成可执行文件,下面这篇文章主要给大家介绍了关于使用pyinstaller打包.exe文件的相关资料,需要的朋友可以参考下

  5. 基于Python实现射击小游戏的制作

    这篇文章主要介绍了如何利用Python制作一个自己专属的第一人称射击小游戏,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起动手试一试

  6. Python list append方法之给列表追加元素

    这篇文章主要介绍了Python list append方法如何给列表追加元素,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  7. Pytest+Request+Allure+Jenkins实现接口自动化

    这篇文章介绍了Pytest+Request+Allure+Jenkins实现接口自动化的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. 利用python实现简单的情感分析实例教程

    商品评论挖掘、电影推荐、股市预测……情感分析大有用武之地,下面这篇文章主要给大家介绍了关于利用python实现简单的情感分析的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

  9. 利用Python上传日志并监控告警的方法详解

    这篇文章将详细为大家介绍如何通过阿里云日志服务搭建一套通过Python上传日志、配置日志告警的监控服务,感兴趣的小伙伴可以了解一下

  10. Pycharm中运行程序在Python console中执行,不是直接Run问题

    这篇文章主要介绍了Pycharm中运行程序在Python console中执行,不是直接Run问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

返回
顶部