Python学生信息管理系统_python管理员登录代码-程序员宅基地

技术标签: python  开发语言  

先上代码,注释,运行结果在代码图下面,觉得还行留个赞吧!!!

刚学python一两星期,有java基础写的, 我不会的自己去看菜鸟教程啥的,花了一整天写完的

import os #导入包
filename = 'student.txt'
# 管理员账户默认    用户名:小黑     密码:123456

# -------------我是一条分割线-------------------
# 主要界面
def menum():
    loop = True
    while loop:
        print("==============欢迎登录学生管理系统==============")
        print("\t\t\t\t1.管理员登录系统")
        print("\t\t\t\t2.学生登录系统")
        print("\t\t\t\t9.退出系统")
        key = int(input("请输入您的选择: "))

        # 根据用户的输入, 来梳理不同的逻辑
        if key == 1: #管理员登录
            userId = input("请输入管理员用户名: ")
            pwd = input("请输入密码: ")
            if userPwd(userId, pwd, key):
                print("============欢迎 (管理员", userId, "登录成功)========")
                # 进入到二级菜单
                while True:
                    print("==============学生信息管理系统二级菜单(管理员:", userId, ") ==============")
                    print("\t\t\t\t1. 添加_学生信息")
                    print("\t\t\t\t2. 查找_学生信息")
                    print("\t\t\t\t3. 删除_学生信息")
                    print("\t\t\t\t4. 修改_学生信息")
                    print("\t\t\t\t5. 排序_学生信息")
                    print("\t\t\t\t6. 显示所有学生信息")
                    print("\t\t\t\t7. 打印学生信息文件到电脑")
                    print("\t\t\t\t0. 退出登录")
                    print("-----------------------------------------------------------------------\n\n")
                    key = input("请输入您的选择: ")
                    if key == '1':
                        # 添加 add_student()
                        add_student()
                    elif key == '2':
                        # 查找
                        find_student()
                    elif key == '3':
                        # 删除
                        delete_student()
                    elif key == '4':
                        # 修改
                        modify_student()
                    elif key == '5':
                        # 排序
                        sort_student()
                    elif key == '6':
                        # 显示
                        show()
                    elif key == '7':
                        print_StudentInfo_FileToYourComputer()
                    elif key == '0':
                        # 退出登录
                        key = int(input("你真退出登录吗o(╥﹏╥)o(1.拜拜下次一定 2.再用一次,最后用一次): "))
                        if key == 1:
                            print("用户退出登录....")
                            break
                        elif key == 2:
                            continue
            else:
                print("用户名或密码输入错误, 登录失败")
                continue
        elif key == 2:#学生登录
            userId = input("请输入学生用户名: ")
            pwd = input("请输入密码: ")
            if userPwd(userId, pwd, key):
                print("============欢迎 (学生", userId, "登录成功)========")
                # 进入到二级菜单
                while True:
                    print("==============学生信息管理系统二级菜单(学生:", userId, ") ==============")
                    print("\t\t\t\t1. 查找_学生信息")
                    print("\t\t\t\t2. 排序_学生信息")
                    print("\t\t\t\t3. 显示所有学生信息")
                    print("\t\t\t\t4. 打印学生信息文件到电脑")
                    print("\t\t\t\t0. 退出登录")
                    print("-----------------------------------------------------------------------\n\n")
                    key = input("请输入您的选择: ")
                    if key == '1':
                        find_student()
                    elif key == '2':
                        sort_student()
                    elif key == '3':
                        show()
                    elif key == '4':
                        print_StudentInfo_FileToYourComputer()
                    elif key == '0':
                        # 退出登录
                        key = int(input("你真退出登录吗o(╥﹏╥)o(1.拜拜下次一定 2.再用一次,最后用一次): "))
                        if key == 1:
                            print("用户退出登录....")
                            break
                        elif key == 2:
                            continue
            else:
                print("用户名或密码输入错误, 登录失败")
                continue
        elif key == 9:
            key = int(input("确定要退出系统吗(1.是 2.否): "))
            if key == 1:
                loop = False
                break
            elif key == 2:
                continue
    if not loop:
        return False


# 在这里面设置好了管理员的账号密码 可以调用进行验证, 返回布尔值
def userPwd(userId, pwd, key):
    #以后可以用字典存
    # if userId == "小黑" and pwd == "123456":
    #     return True
    # else:
    #     return False
    user_list1 = [{"user":"张老师","pwd":"123456"},
                 {"user":"李老师","pwd":"173384"},
                 {"user":"韩老师","pwd":"777777"},
                 {"user":"红老师","pwd":"888888"},
                 {"user":"王老师","pwd":"999999"}]

    user_list2 = [{"user":"张三","pwd":"123456"},
                 {"user":"李四","pwd":"173384"},
                 {"user":"法海","pwd":"777777"},
                 {"user":"周芷若","pwd":"888888"},
                 {"user":"张无忌","pwd":"999999"}]
    if key == 1:
        for i in user_list1:
            if i['user'] == userId and i['pwd'] == pwd:
                return True
    elif key == 2:
        for i in user_list2:
            if i['user'] == userId and i['pwd'] == pwd:
                return True
    return False


# -------------------添加学生信息--------------------------
def add_student():
    studentList = []  # 存储学生
    while True:
        #调用函数判断输入的 ID 和 姓名 是否合法
        studentId = legal_id()
        studentName = legal_name()
        #调用函数返回一个学生成绩列表
        sgl = get_student_grades(); #student_grades_list 简写成sgl
        #把学生信息保存到字典
        student = {"id":studentId,"姓名":studentName,"JavaScript":sgl[0],"Java":sgl[1],"Python":sgl[2],"英语":sgl[3],"离散数学":sgl[4]}
        #将学生信息添加到列表中
        studentList.append(student)
        print("录入学生 ",studentName," 信息成功...")
        ans = input("是否继续添加(1.继续 2.退出): ")
        if ans == "1":
            continue
        elif ans == "2":
            break
    #将录入的学生列表进行保存 保存在一个文件中
    save(studentList)
    print("学生信息录入完毕")

#保存录入的学生信息到文件中
def save(list):
    # 'a'追加模式打开文件, 如果没有文件会出错,用try捕捉 ,如果没有就'w'用写入的方式
    try:
        #使用“a”模式。把所有要写入文件的数据都追加到文件的末尾,
        # 即使你使用了seek()指向文件的其他地方,如果文件不存在,将自动被创建。
        student_txt = open(filename,'a',encoding='utf-8')
    except:
        #表示打开一个文件只用于写入。采用该模式时需小心。因为如果指定的文件已经存在
        # Python将在返回文件对象前清空该文件。如果文件不存在,则创建新文件
        student_txt = open(filename,'w',encoding='utf-8')
    for i in list:
        student_txt.write(str(i) + "\n")
    student_txt.close()

# 判断输入的学生id是否合法
def legal_id():
    #后面在写个方法判断一下不能输入已经存在的id
    while True:
        id = input("请输入学生id(例:001): ")
        if not id:
            print("您的输入有误, 请重新输入学生id...")
        else:
            break
    return id
# 判断学生输入姓名是否合法
def legal_name():
    while True:
        name = input("请输入学生姓名(例:张三): ")
        if not name:
            print("您的输入有误, 请重新输入...")
        else:
            break
    return name
def get_student_grades():
    #定义一组默认的课程
    course = []
    course1 = ['JavaScript', 'Java', 'Python', '英语', '离散数学']
    i = 0
    while i < len(course1):
        #输入可能会出现异常, 用try来捕捉一下
        try:
            print('请输入您的',course1[i],'成绩: ',end=" ")
            temp = float(input())
            #先判断, 再添加
            if temp < 0 or temp > 100:
                print("输入成绩需在0-100以内, 请重新输入....")
                continue
            course.append(temp)
        except:
            print("输入不合法,请重新输入....")
        i+=1
    return course

# -------------我是一条分割线-------------------
#删除
def delete_student():
    old_list = [] #初始化一个列表
    loop = False  #判断是否删除
    #删除前先打印学生信息
    show()
    while True:
        pick = input("请选择: 1.按ID删除 2.按姓名删除")
        if pick == '1':
            id = input("请输入您要删除的学生ID: ")
            if id != '':
                #判断是否存在这个文件
                if os.path.exists(filename):
                    with open(filename,'r',encoding='utf-8') as file: #存在则打开文件
                        old_list = file.readlines() #按行读取,放入列表中
                #如果有内容布尔值为True, 空为False
                if old_list:
                    with open(filename, 'w', encoding='utf-8') as outPutStream:
                        d = {}
                        for item in old_list:
                            d = dict(eval(item))
                            #这里判断字典里的id, 如果不相等则把字典写入文件中
                            #如果匹配到了则不写入到文件中, 就没有那位学生信息了, 等于删除了
                            if d['id'] != id:
                                outPutStream.write(str(d)+'\n')
                            else:
                                loop = True
                        if loop:
                            print("id为 {} 的学生信息已被删除".format(id))
                        else:
                            print("没有找到id为 {} 的学生".format(id))
                else:
                    print("没有学生信息")
                    break
                show() #打印删除以后的学生信息
                ans = input("是否继续删除(1.继续 2.退出): ")
                if ans == '1':
                    continue
                elif ans == '2':
                    break
            else:
                print('学生id不能为空, 请重新输入')
                continue
        elif pick == '2':
            name = input("请输入您要删除的学生姓名: ")
            if name != '':
                #判断是否存在这个文件
                if os.path.exists(filename):
                    with open(filename,'r',encoding='utf-8') as file: #存在则打开文件
                        old_list = file.readlines() #按行读取,放入列表中
                #如果有内容布尔值为True, 空为False
                if old_list:
                    with open(filename, 'w', encoding='utf-8') as outPutStream:
                        d = {}
                        for item in old_list:
                            d = dict(eval(item))
                            #这里判断字典里的id, 如果不相等则把字典写入文件中
                            #如果匹配到了则不写入到文件中, 就没有那位学生信息了, 等于删除了
                            if d['姓名'] != id:
                                outPutStream.write(str(d)+'\n')
                            else:
                                loop = True
                        if loop:
                            print("姓名为 {} 的学生信息已被删除".format(id))
                        else:
                            print("没有找到姓名为 {} 的学生".format(id))
                else:
                    print("没有学生信息")
                    break
                show() #打印删除以后的学生信息
                ans = input("是否继续删除(1.继续 2.退出): ")
                if ans == '1':
                    continue
                elif ans == '2':
                    break
            else:
                print('学生id不能为空, 请重新输入')
                continue
        else:
            print("输入不合法...")
            continue

#-------------我是一条分割线-------------------
#修改
def modify_student():

    while True:
        loop = False
        # show()
        if os.path.exists(filename):
            with open(filename, 'r',encoding='utf-8') as intputStream:
                oldList = intputStream.readlines()
        else:
            return
        show()
        studentId = input("请输入要修改学生ID: ")
        if studentId != "":
            with open(filename,'w',encoding='utf-8') as outputStream:
                for item in oldList:
                    d = dict(eval(item))
                    #找到和输入id相同的学生, 修改信息, 如果相等则修改, 然后在写入
                    #如果不等则直接写入
                    if d['id'] == studentId:
                        loop = True
                        print("找到id为{}学生信息,可以开始修改".format(studentId))
                        #输入成绩可能出现错误, 用try和while来搞, 出错则重新输入
                        while True:
                            try:
                                #['JavaScript', 'Java', 'Python', '英语', '离散数学']
                                d['姓名'] = input("请输入新的姓名: ")
                                d['JavaScript'] = float(input("请输入JavaScript成绩(0-100): "))
                                d['Java'] = float(input("请输入Java成绩(0-100): "))
                                d['Python'] = float(input("请输入Python成绩(0-100): "))
                                d['英语'] = float(input("请输入英语成绩(0-100): "))
                                d['离散数学'] = float(input("请输入离散数学成绩(0-100): "))
                                break
                            except:
                                print("输入有误, 请重新输入....")
                            else:
                                break
                        outputStream.write(str(d)+"\n")
                    else:
                        outputStream.write(str(d)+"\n")
                # print("成功修改id:{} 的学生信息".format(studentId))
            if loop:
                print("成功修改id:{} 的学生信息".format(studentId))
            else:
                print("未找到该id为{}的学生,无法修改....".format(studentId))
            ans = input("是否继续修改其他学生信息(1.继续 2.退出): ")
            if ans == '1':
                continue
                #modify_student() 有bug
            elif ans == '2':
                #return
                show()
                break

# -------------我是一条分割线-------------------
#查找
def find_student():
    newStudent = [] #可能会有同名的人, 定义个列表
    #设置为空, 下面判断选择了姓名还是id的时候判断不为空就用哪个来查询
    while True:
        id = '';
        name = '';
        #判断括号里的文件是否存在
        if os.path.exists(filename):
            key = input("请选择: 1.按ID查找 2.按姓名查找 : ")
            if key == '1':
                id = input("请输入要查询的学生ID: ")
            elif key == '2':
                name = input("请输入要查询的学生姓名: ")
            else:
                print("输入有误, 请重新输入")
                #find_student() 这样调用有bug
                continue
                #'r' 只读
            with open(filename,'r',encoding='utf-8') as intputStream:
                student = intputStream.readlines()
                for item in student:
                    d = dict(eval(item))
                    if id != '': #用id查询
                        if d['id'] == id:
                            newStudent.append(d)
                    elif name != '': #用姓名查询
                        if d['姓名'] == name:
                            newStudent.append(d)
            #显示查询结果
            show_student(newStudent)
            #清空列表
            newStudent.clear()
            ans = input("是否继续修改其他学生信息(1.继续 2.退出): ")
            if ans == '1':
                #find_student() 这样调用有bug
                continue
            elif ans == '2':
                return
        else:
            print('系统暂无学生信息...不能查询...快去添加几条学生信息把(ˆ◡ˆԅ)')
            return
#显示查询结果
def show_student(list):
    if len(list) == 0:
        print("没有查询到该学生信息....可能没有这个学生吧╮(╯▽╰)╭快去添加学生信息把")
        return
    #定义一个显示格式               #['JavaScript', 'Java', 'Python', '英语', '离散数学']
    format_title = '{:^6}\t{:^10}\t{:^10}\t{:^10}\t{:^10}\t{:^10}\t{:^10}\t{:^10}\t{:^10}'
    print(format_title.format('id','姓名',"JavaScript成绩","Java成绩","Python成绩","英语成绩","离散数学成绩","总分","平均分"))
    #定义显示格式
    format_data = '{:^7}\t {:^11}\t{:^14}\t{:^14}\t{:^14}\t{:^14}\t{:^14}\t{:^14}\t{:^14}'
    for item in list:
        sum = int(item.get('JavaScript')) + int(item.get('Java')) + int(item.get('Python')) + int(item.get('英语')) + int(item.get('离散数学'))
        avg = round(sum/5,2)
        print(format_data.format(item.get('id'),
                                 item.get('姓名'),
                                 item.get('JavaScript'),
                                 item.get('Java'),
                                 item.get('Python'),
                                 item.get('英语'),
                                 item.get('离散数学'),
                                 sum,avg))
    print()

# -------------我是一条分割线-------------------
#显示
def show():
    student_list = []
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as inputStream:
            student = inputStream.readlines()
            for item in student:
                student_list.append(eval(item))
            if student_list:
                show_student(student_list)
    else:
        print('系统暂无学生信息...不能查询...快去添加几条学生信息把(ˆ◡ˆԅ)')

# -------------我是一条分割线-------------------
#排序
def sort_student():
    #student_newList=[]
    #显示排序之前的学生信息
    loop = True
    show()
    #判断是否有这个文件
    if os.path.exists(filename):
        with open(filename,'r',encoding='utf-8') as intputStream:
            studentList = intputStream.readlines()
        student_newList=[]
        for item in studentList:
            d = dict(eval(item))
            student_newList.append(d)
    else:
        return
    while loop:
        #['JavaScript', 'Java', 'Python', '英语', '离散数学']
        n = input("请选择以哪科成绩进行排序(1.JavaScript 2.Java 3.Python 4.英语 5.离散数学 6.总成绩 7.平均分 8.学号)")
        if n == '1':
            key = sortKey()
            student_newList.sort(key=lambda x:int(x['JavaScript']), reverse=key)
            show_student(student_newList)
        elif n == '2':
            key = sortKey()
            student_newList.sort(key=lambda x:int(x['Java']), reverse=key)
            show_student(student_newList)
        elif n == '3':
            key = sortKey()
            student_newList.sort(key=lambda x:int(x['Python']), reverse=key)
            show_student(student_newList)
        elif n == '4':
            key = sortKey()
            student_newList.sort(key=lambda x:int(x['英语']), reverse=key)
            show_student(student_newList)
        elif n == '5':
            key = sortKey()
            student_newList.sort(key=lambda x:int(x['离散数学']), reverse=key)
            show_student(student_newList)
        elif n == '6':
            key = sortKey()
            student_newList.sort(key=lambda x: int(x['JavaScript']) + int(x['Java']) + int(x['Python']) + int(x['英语']) + int(x['离散数学']), reverse=key)
            show_student(student_newList)
        elif n == '7':
            key = sortKey()
            student_newList.sort(key=lambda x: (int(x['JavaScript']) + int(x['Java']) + int(x['Python']) + int(x['英语']) + int(x['离散数学']))/5, reverse=key)
            show_student(student_newList)
        elif n == '8':
            key = sortKey()
            student_newList.sort(key=lambda x:int(x['id']), reverse=key)
            show_student(student_newList)
        else:
            print("您的输入有误, 请重新输入....")
            continue
        while True:
            key = input("是否继续使用排序功能(1.继续使用 2.下次一定):")
            if key == '1':
                break
            elif key == '2':
                loop = False
                break
            else:
                print("你这输入不合法呀老铁, 请重新输入")
                continue

def sortKey():
    loop = True
    while True:
        ans = input("1.升序 2.降序 :")
        if ans == '1':
            loop = False
            break
        elif ans == '2':
            break
        else:
            print("你这不升不降的,你在玩系统是吧, 赶紧重新输入...")
    return loop

# -------------我是一条分割线-------------------
#打印学生信息文件到电脑......我也不知道怎么命名了....这名笑死我
#还是有小bug的..
def print_StudentInfo_FileToYourComputer():
    dest = input("请输入您想要把文件保存到哪个目录(例如:D:\\\student.txt): ")
    if os.path.exists(filename):
        with open(filename, 'r',encoding='utf-8') as intputStream:
            studentList = intputStream.readlines()
    else:
        return
    if dest != None:
        with open(dest, 'w',encoding="utf-8") as outputStream:
            for itme in studentList:
                outputStream.write(str(itme)+'\n')
        print('已将学生信息文件保存到',dest,'下')


# -------------我是一条分割线-------------------
if not menum():
    print("系统退出......欢迎下次使用")
    sys.exit(0)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_68967484/article/details/127282863

智能推荐

海康威视网络摄像头开发流程(五)------- 直播页面测试_ezuikit 测试的url-程序员宅基地

文章浏览阅读3.8k次。1、将下载好的萤石js插件,添加到SoringBoot项目中。位置可参考下图所示。(容易出错的地方,在将js插件在html页面引入时,发生路径错误的问题)所以如果对页面中引入js的路径不清楚,可参考下图所示存放路径。2、将ezuikit.js引入到demo-live.html中。(可直接将如下代码复制到你创建的html页面中)<!DOCTYPE html><html lan..._ezuikit 测试的url

如何确定组态王与多动能RTU的通信方式_组态王ua-程序员宅基地

文章浏览阅读322次。第二步,在弹出的对话框选择,设备驱动—>PLC—>莫迪康—>ModbusRTU—>COM,根据配置软件选择的协议选期期,这里以此为例,然后点击“下一步”。第四步,把使用虚拟串口打勾(GPRS设备),根据需要选择要生成虚拟口,这里以选择KVCOM1为例,然后点击“下一步”设备ID即Modbus地址(1-255) 使用DTU时,为下485接口上的设备地址。第六步,Modbus的从机地址,与配置软件相同,这里以1为例,点击“下一步“第五步,Modbus的从机地址,与配置软件相同,这里以1为例,点击“下一步“_组态王ua

npm超详细安装(包括配置环境变量)!!!npm安装教程(node.js安装教程)_npm安装配置-程序员宅基地

文章浏览阅读9.4k次,点赞22次,收藏19次。安装npm相当于安装node.js,Node.js已自带npm,安装Node.js时会一起安装,npm的作用就是对Node.js依赖的包进行管理,也可以理解为用来安装/卸载Node.js需要装的东西_npm安装配置

火车头采集器AI伪原创【php源码】-程序员宅基地

文章浏览阅读748次,点赞21次,收藏26次。大家好,小编来为大家解答以下问题,python基础训练100题,python入门100例题,现在让我们一起来看看吧!宝子们还在新手村练级的时候,不单要吸入基础知识,夯实自己的理论基础,还要去实际操作练练手啊!由于文章篇幅限制,不可能将100道题全部呈现在此除了这些,下面还有我整理好的基础入门学习资料,视频和讲解文案都很齐全,用来入门绝对靠谱,需要的自提。保证100%免费这不,贴心的我爆肝给大家整理了这份今天给大家分享100道Python练习题。大家一定要给我三连啊~

Linux Ubuntu 安装 Sublime Text (无法使用 wget 命令,使用安装包下载)_ubuntu 安装sumlime text打不开-程序员宅基地

文章浏览阅读1k次。 为了在 Linux ( Ubuntu) 上安装sublime,一般大家都会选择常见的教程或是 sublime 官网教程,然而在国内这种方法可能失效。为此,需要用安装包安装。以下就是使用官网安装包安装的教程。打开 sublime 官网后,点击右上角 download, 或是直接访问点击打开链接,即可看到各个平台上的安装包。选择 Linux 64 位版并下载。下载后,打开终端,进入安装..._ubuntu 安装sumlime text打不开

CrossOver for Mac 2024无需安装 Windows 即可以在 Mac 上运行游戏 Mac运行exe程序和游戏 CrossOver虚拟机 crossover运行免安装游戏包-程序员宅基地

文章浏览阅读563次,点赞13次,收藏6次。CrossOver24是一款类虚拟机软件,专为macOS和Linux用户设计。它的核心技术是Wine,这是一种在Linux和macOS等非Windows操作系统上运行Windows应用程序的开源软件。通过CrossOver24,用户可以在不购买Windows授权或使用传统虚拟机的情况下,直接在Mac或Linux系统上运行Windows软件和游戏。该软件还提供了丰富的功能,如自动配置、无缝集成和实时传输等,以实现高效的跨平台操作体验。

随便推点

一个用聊天的方式让ChatGPT写的线程安全的环形List_为什么gpt一写list就卡-程序员宅基地

文章浏览阅读1.7k次。一个用聊天的方式让ChatGPT帮我写的线程安全的环形List_为什么gpt一写list就卡

Tomcat自带的设置编码Filter-程序员宅基地

文章浏览阅读336次。我们在前面的文章里曾写过Web应用中乱码产生的原因和处理方式,旧文回顾:深度揭秘乱码问题背后的原因及解决方式其中我们提到可以通过Filter的方式来设置请求和响应的encoding,来解..._filterconfig selectencoding

javascript中encodeURI和decodeURI方法使用介绍_js encodeur decodeurl-程序员宅基地

文章浏览阅读651次。转自:http://www.jb51.net/article/36480.htmencodeURI和decodeURI是成对来使用的,因为浏览器的地址栏有中文字符的话,可以会出现不可预期的错误,所以可以encodeURI把非英文字符转化为英文编码,decodeURI可以用来把字符还原回来_js encodeur decodeurl

Android开发——打包apk遇到The destination folder does not exist or is not writeable-程序员宅基地

文章浏览阅读1.9w次,点赞6次,收藏3次。前言在日常的Android开发当中,我们肯定要打包apk。但是今天我打包的时候遇到一个很奇怪的问题Android The destination folder does not exist or is not writeable,大意是目标文件夹不存在或不可写。出现问题的原因以及解决办法上面有说报错的中文大意是:目标文件夹不存在或不可写。其实问题就在我们的打包界面当中图中标红的Desti..._the destination folder does not exist or is not writeable

Eclipse配置高大上环境-程序员宅基地

文章浏览阅读94次。一、配置代码编辑区的样式 <1>打开Eclipse,Help —> Install NewSoftware,界面如下: <2>点击add...,按下图所示操作: name:随意填写,Location:http://eclipse-color-th..._ecplise高大上设置

Linux安装MySQL-5.6.24-1.linux_glibc2.5.x86_64.rpm-bundle.tar_linux mysql 安装 mysql-5.6.24-1.linux_glibc2.5.x86_6-程序员宅基地

文章浏览阅读2.8k次。一,下载mysql:http://dev.mysql.com/downloads/mysql/; 打开页面之后,在Select Platform:下选择linux Generic,如果没有出现Linux的选项,请换一个浏览器试试。我用的谷歌版本不可以,换一个别的浏览器就行了,如果还是不行,需要换一个翻墙的浏览器。 二,下载完后解压缩并放到安装文件夹下: 1、MySQL-client-5.6.2_linux mysql 安装 mysql-5.6.24-1.linux_glibc2.5.x86_64.rpm-bundle