《Python系列》Python实战记录

Python实战记录

一、Python学生信息管理系统

1.需求分析

1.录入学生信息
2.查找学生信息
3.删除学生信息
4.修改学生信息
5.排序
6.统计学生总人数
7.显示所有学生信息
0.退出系统

在这里插入图片描述

2.开发必备

系统开发环境:
    操作系统:window10
    Python解释器版本:Python3.7
    开发工具:Pycharm
    Python内置模块:os,re
项目目录结构:
    main.py
    menu.py
    operate.py
    save.py
    display.py

3.主函数设计

在主函数中通过调用各个函数实现需求分析内容
1.录入学生信息    insert()
2.查找学生信息    find()
3.删除学生信息    delete()
4.修改学生信息    modify()
5.排序           sort()
6.统计学生总人数   total()
7.显示所有学生信息  show()
0.退出系统

from menu import menu
import operate


def main():
    while 1:
        menu()
        choice = int(input('请输入你需要的功能:'))
        if choice in range(0,8):
            if choice == 0:
                answer = input('你确定要退出系统吗?y/n')
                if answer in ('y','Y'):
                    print('谢谢你的使用')
                    break
                else:
                    continue
            elif choice == 1:
                operate.insert()
            elif choice == 2:
                operate.find()
            elif choice == 3:
                operate.delete()
            elif choice == 4:
                operate.modify()
            elif choice == 5:
                operate.sort()
            elif choice == 6:
                operate.total()
            elif choice == 7:
                operate.show()

if __name__ == '__main__':
    main()

3.1 menu函数设计

def menu():
    print('学生信息管理系统'.center(50,'='))
    print('功能菜单'.center(50,'-'))
    print('\t\t\t\t\t1.录入学生信息')
    print('\t\t\t\t\t2.查找学生信息')
    print('\t\t\t\t\t3.删除学生信息')
    print('\t\t\t\t\t4.修改学生信息')
    print('\t\t\t\t\t5.排序')
    print('\t\t\t\t\t6.统计学生总人数')
    print('\t\t\t\t\t7.显示所有学生信息')
    print('\t\t\t\t\t0.退出系统')
    print('-'.center(50,'-'))

3.2 operate函数设计

# Author : zxy
# Date : 2022/5/21 23:53
import display
import save
import os
def insert(filename):
    student_list = []
    while True:
        id = input('请输入ID(如1001):')
        if not id:
            break
        name = input('请输入姓名:')
        if not name:
            break
        try:
            english = int(input('请输入英语成绩:'))
            python = int(input('请输入Python成绩:'))
            java = int(input('请输入Java成绩:'))
        except:
            print('输入有误!!请重新输入!!')
            continue
        # 将信息报错在字典中
        student = {'id':id,'name':name,'english':english,'python':python,'java':java}
        student_list.append(student)
        answer = input('是否继续添加?y/n\n')
        if answer in ('y','Y'):
            continue
        else:
            break
    save.save(student_list,filename)

def find(filename):
    student_lst = []
    while True:
        id = ''
        name = ''
        if os.path.exists(filename):
            mode = int(input('按ID查找请输入1,按姓名查找请输入2:'))
            if mode == 1:
                id = input('请输入学生ID:')
            elif mode == 2:
                name = input('请输入学生姓名:')
            else:
                print('你输入有误,请重新输入!!!')
                find(filename)
            with open(filename,'r',encoding='utf-8') as rfile:
                students = rfile.readlines()
                for student in students:
                    dic = dict(eval(student))
                    if id != '':
                        if dic['id'] == id:
                            student_lst.append(dic)
                    elif name != '':
                        if dic['name'] == name:
                            student_lst.append(dic)
            display.show_student(student_lst)
            student_lst.clear()
            answer = input('是否继续查询?y/n')
            if answer in ('y','Y'):
                continue
            else:
                break
        else:
            print('没有学生信息!!!')


def delete(filename):
    while True:
        student_id = input('请输入要删除的学生的ID:')
        if student_id != '':
            if os.path.exists(filename):
                with open(filename,'r',encoding='utf-8') as rfile:
                    student_old = rfile.readlines()
            else:
                student_old = []
            flag = False
            if student_old:
                with open(filename,'w',encoding='utf-8') as wfile:
                    dic = {}
                    for item in student_old:
                        dic = dict(eval(item))
                        if dic['id'] != student_id:
                            wfile.write(str(dic)+'\n')
                        else:
                            flag = True
                    if flag:
                        print('id为{}的学生信息已被删除'.format(student_id))
                    else:
                        print(f'没有找到ID为{student_id}的学生信息')
            else:
                print('没有学生信息')
                break
            show(filename)
            answer = input('是否继续删除?y/n' + '\n')
            if answer in ('y','Y'):
                continue
            else:
                break



def modify(filename):
    while True:
        answer = input('请输入要修改的学生ID:')
        if answer != '':
            if os.path.exists(filename) :
                with open(filename,'r',encoding='utf-8') as rfile:
                    student_old = rfile.readlines()
            else:
                student_old = []

            flag = False
            if student_old:
                with open(filename,'w',encoding='utf-8') as wfile:
                    dic = {}
                    for student in student_old:
                        dic = dict(eval(student))
                        if dic['id'] == answer:
                            print('找到这个名学生,可以修改他的相关信息了')
                            name = input('请输入姓名:')
                            dic['name'] = name
                            english = input('请输入英语成绩:')
                            dic['english'] = english
                            python = input('请输入Python成绩:')
                            dic['python'] = python
                            java = input('请输入Java成绩:')
                            dic['java'] = java
                            wfile.write(str(dic)+'\n')
                        else:
                            wfile.write(str(dic)+'\n')
                            flag = True

                    if not flag:
                        print('ID为{0}的学生信息修改成功'.format(answer))
                    else:
                        print('你输入的学生ID:{}不存在!!!'.format(answer))
            else:
                print('没有学生信息!!!')
                break
            show(filename)
            answer = input('是否继续修改其他学生信息?y/n'+'\n')
            if answer in ('y','Y'):
                continue
            else:
                break
        else:
            print('请输入正确的学生ID')

def sort(filename):
    show(filename)
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            students = rfile.readlines()
        student_new = []
        for student in students:
            dic = dict(eval(student))
            student_new.append(dic)
    else:
        print('未录入学生信息!!!')
    asc_or_desc = input('请选择(0升序,1降序):')
    if asc_or_desc == '0':
        asc_or_desc_bool = False
    elif asc_or_desc == '1':
        asc_or_desc_bool = True
    else:
        print('你输入有误,请重新输入!!!')
        sort(filename)
    mode = input('请选择排序方式(1.按英语排序,2.按Python排序,3.按Java排序,0.按总成绩排序):')
    if mode == '1':
        student_new.sort(key=lambda x : int(x['english']),reverse=asc_or_desc_bool)
    elif mode == '2':
        student_new.sort(key=lambda x : int(x['python']),reverse=asc_or_desc_bool)
    elif mode == '3':
        student_new.sort(key=lambda x : int(x['java']),reverse=asc_or_desc_bool)
    elif mode == '5':
        student_new.sort(key=lambda x : int(x['english']) + int(x['python']) + int(x['java']) ,reverse=asc_or_desc_bool)
    else:
        print('你的输入有误,请重新输入!!!')
        sort(filename)
    display.show_student(student_new)

def  total(filename):
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            students = rfile.readlines()
        if students != '':
            print('一共有{}名学生'.format(len(students)))
        else:
            print('学生信息为空!!!')
    else:
        print('暂未报错学生信息!!!')

def  show(filename):
    student_lst = []
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as rfile:
            students = rfile.readlines()
            for student in students:
                dic = dict(eval(student))
                student_lst.append(dic)
        display.show_student(student_lst)
        student_lst.clear()
    else:
        print('暂未保存学生信息!!!')

3.3 save()函数

def save(lst,filename):
    try:
        stu_data = open(filename,'a',encoding='utf-8')
    except:
        stu_data = open(filename,'w',encoding='utf-8')
    for item in lst:
        stu_data.write(str(item)+'\n')
    stu_data.close()

3.4 display()函数

def show_student(lst):
    if len(lst) == 0:
        print('没有查询到学生信息,无数据显示!!!')
        return
    format_title = '{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}\t'
    print(format_title.format('ID','姓名','英语成绩','Python成绩','Java成绩','总成绩'))
    format_data = '{:^6}\t{:^12}\t{:^10}\t{:^10}\t{:^10}\t{:^10}\t'
    for student in lst:
        print(format_data.format(student.get('id'),
                                 student.get('name'),
                                 student.get('english'),
                                 student.get('python'),
                                 student.get('java'),
                                 int(student.get('english')) + int(student.get('python')) + int(student.get('java'))
                                 ))

3.5 项目打包

安装:pip install PyInstaller
单文件打包:
    pyinstaller -F main.py [打包exe]
    pyinstaller -F -w main.py [不带控制台打包]
    pyinstaller -F -i main.ico main.py [指定图标打包]
多文件打包:
    1.pyi-makespec main.py(将主函数生成对应的spec文件)
    2.修改spec文件,i按察Analysis下是否包含所有py文件,检查pathex的项目路径是否正确
    3.pyinstaller main.spec(对spec文件进行pyinstaller安装)

main.spec文件修改

Analysis:
    ['main.py','menu.py','operate.py','display.py','save.py'],<将所有需要打包py文件写入>
    pathex=['E:\\BigData\\date\\PyCharm\\May2\\project'],<写入正确的项目路径>
    datas=[('date\\student.txt','date'),('icon.ico','icon')],<首先是项目中文件,其次是打包后文件夹名称>

exe:
    name='学生信息管理系统',<指定exe名称>
    icon='icon.ico',<指定图标打包>

在这里插入图片描述

图片转ico图标工具

二、Python实现pdf合并功能,并打包生成应用[无Python环境下使用]

功能实现源码以及打包后应用文件

1.应用功能描述

应用包含:
	有一个pdf文件夹,将需要合并的pdf放入该文件夹中,依序读取合并
	有一个exe可执行文件,双击即可执行并根据指令实现pdf合并功能

2.Python代码

# Author : zxy
# Date : 2022/5/24 23:27
# Desc : 开发合并PDF功能,并打包成可执行exe文件

import os
# 使用os模块的walk函数,搜索出指定目录下的全部PDF文件
from PyPDF2 import PdfFileReader, PdfFileWriter


# 获取同一目录下的所有PDF文件的绝对路径
def getFileName(filedir):

    file_list = [os.path.join(root, filespath) \
                 for root, dirs, files in os.walk(filedir) \
                 for filespath in files \
                 if str(filespath).endswith('pdf')
                 ]
    return file_list if file_list else []

# 合并同一目录下的所有PDF文件
def MergePDF(filepath, outfile):

    output = PdfFileWriter()
    outputPages = 0
    pdf_fileName = getFileName(filepath)

    if pdf_fileName:
        for pdf_file in pdf_fileName:
            print("路径:%s"%pdf_file)

            # 读取源PDF文件
            input = PdfFileReader(open(pdf_file, "rb"))

            # 获得源PDF文件中页面总数
            pageCount = input.getNumPages()
            outputPages += pageCount
            print("页数:%d"%pageCount)

            # 分别将page添加到输出output中
            for iPage in range(pageCount):
                output.addPage(input.getPage(iPage))

        print("合并后的总页数:%d"%outputPages)
        # 写入到目标PDF文件
        outputStream = open(os.path.join(filepath, outfile), "wb")
        output.write(outputStream)
        outputStream.close()
        print("PDF文件合并完成!")

    else:
        print("没有可以合并的PDF文件!")

# 主函数
if __name__ == '__main__':
    while True:
        print('亲爱的女士\先生,很高兴为你服务!!!')
        outfile1 = input('请先输入合并后的文件名:')
        outfile = outfile1+'.pdf'
        file_dir = r'pdf'
        MergePDF(file_dir, outfile)
        answer = input('是否继续合并?y/n')
        if answer == 'y':
            continue
        else:
         break


3.运行结果测试

亲爱的女士\先生,很高兴为你服务!!!
请先输入合并后的文件名:3
路径:pdf\1.pdf
页数:3
路径:pdf\2.pdf
页数:4
合并后的总页数:7
PDF文件合并完成!
是否继续合并?y/ny
亲爱的女士\先生,很高兴为你服务!!!
请先输入合并后的文件名:4
路径:pdf\1.pdf
页数:3
路径:pdf\2.pdf
页数:4
路径:pdf\3.pdf
页数:7
合并后的总页数:14
PDF文件合并完成!
是否继续合并?y/nn

4.打包

初次使用打包功能的时候,需要先下载pyinstaller包

1.将主函数生成对应的spec文件

pyi-makespec .\mergepdf.py

2.修改spec文件
这里主要修改Analysis部分的pathex为项目路径,datas为打包项目中的文件夹
修改EXE部分的name为exe文件的名称,icon为exe可执行文件指定的图标

图片制作ico

......
a = Analysis(
    ['mergepdf.py'],
    pathex=['E:\\BigData\\date\\PyCharm\\PythonStudy\\action\\pdf'],
    binaries=[],
    datas=[('pdf','pdf')],
    hiddenimports=[],
    hookspath=[],
    hooksconfig={},
    runtime_hooks=[],
    excludes=[],
    win_no_prefer_redirects=False,
    win_private_assemblies=False,
    cipher=block_cipher,
    noarchive=False,
)

......
exe = EXE(
    pyz,
    a.scripts,
    [],
    exclude_binaries=True,
    name='Pdf合并',
    debug=False,
    bootloader_ignore_signals=False,
    strip=False,
    upx=True,
    console=True,
    disable_windowed_traceback=False,
    argv_emulation=False,
    target_arch=None,
    codesign_identity=None,
    entitlements_file=None,
    icon='pdf.ico',
)
......

3.执行打包spec文件

pyinstaller .\mergepdf.spec

5.使用

5.1.目录一览

pdf文件夹为pdf文件放置目录
Pdf合并.exe为执行合并的应用程序
在这里插入图片描述

5.2.功能测试

首先需要你输入合并文件后,新文件的名称
合并完成后会跟你确认是否继续合并,y是继续合并,n是退出
这里设计询问你是否继续合并是因为,方便你需要合并不同的文件,不需要关闭窗口。只需要将pdf目录下的文件删除并重新上传,然后你在应用窗口继续合并即可
在这里插入图片描述

5.3.测试结果

因为我合并了两次,第一次是按照顺序将1->2->3,这三个合并到合并一次.pdf中。第二次是将1->2->3->合并一次,这四个文件合并到合并两次.pdf文件中
在这里插入图片描述

6.问题解决

6.1.问题

Fatal Python Error:initsencoding: unable to load the file system codec
ModuleNotFoundError: No module named encodings
在这里插入图片描述

6.2.解决

这里出现上午问题的主要原因是我的python环境是3.7,使用python3.7打包的应用可能会有问题,报出No module named encodings问题。所以先打开电脑的设置->应用->应用和功能,在应用与功能中找到Python 3.7Python Launcher这两个应用程序并卸载。然后下载新的Python3.8的安装包,重新安装,安装完成后打包即可。已经测试通过
下载路径:官网
下载路径:资源

三、Python Connect to MySQL

1.install pymysql

pip install pymysql

2.Coding + Solve

Coding

import pymysql
DBHOST = 'ip'
DBPORT = 3306
DBUSER = 'root'
DBPASSWORD = 'root'
DBNAME = 'dbname'
db = pymysql.connect(host=DBHOST, port=DBPORT, user=DBUSER, password=DBPASSWORD, database=DBNAME)
cur = db.cursor(pymysql.cursors.DictCursor)
sql = 'select * from logs'
result = cur.execute(sql)
result = cur.fetchall()
print(result)
db.commit()
cur.close()
db.close()
print('查询成功!')

Problem

Traceback (most recent call last):
  File "D:/date/PyCharm/djangoProject/demo/pymysql.py", line 1, in <module>
    import pymysql
  File "D:\date\PyCharm\djangoProject\demo\pymysql.py", line 7, in <module>
    db = pymysql.connect(host=DBHOST, port=DBPORT, user=DBUSER, password=DBPASSWORD, database=DBNAME)
AttributeError: module 'pymysql' has no attribute 'connect'

Re-Coding

import pymysql
if __name__ == '__main__':
    DBHOST = '101.35.83.222'
    DBPORT = 33060
    DBUSER = 'root'
    DBPASSWORD = '@Zhou147258369'
    DBNAME = 'zxy'
    db = pymysql.connect(host=DBHOST, port=DBPORT, user=DBUSER, password=DBPASSWORD, database=DBNAME)
    cur = db.cursor(pymysql.cursors.DictCursor)
    sql = 'select * from logs'
    result = cur.execute(sql)
    result = cur.fetchall()
    print(result)
    db.commit()
    cur.close()
    db.close()
    print('查询成功!')

Problem

Traceback (most recent call last):
  File "D:/date/PyCharm/djangoProject/demo/pymysql.py", line 8, in <module>
    db = pymysql.connect(host=DBHOST, port=DBPORT, user=DBUSER, password=DBPASSWORD, database=DBNAME)
AttributeError: module 'pymysql' has no attribute 'connect'

Solve

最后发现原因在于,模块和文件名一致了

因为这个文件的名字也是pymysql导致的

调整为py_mysql.py

Result

[{'id': 1, 'log': 'zxy is created'}, {'id': 2, 'log': 'insert into user values (zxy)'}]
查询成功!

  • 4
    点赞
  • 52
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DATA数据猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值