【python】python社交交友平台系统设计与实现(源码+数据库)【独一无二】

news2024/11/18 21:44:08

请添加图片描述


👉博__主👈:米码收割机
👉技__能👈:C++/Python语言
👉公众号👈:测试开发自动化【获取源码+商业合作】
👉荣__誉👈:阿里云博客专家博主、51CTO技术博主
👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。


python社交交友平台系统设计与实现(源码+数据库)【独一无二】


目录

  • python社交交友平台系统设计与实现(源码+数据库)【独一无二】
  • 一、设计要求
  • 二、代码实现
    • 2.1 创建数据库
    • 2.2 用户登录
      • 2.3. 注册功能
      • 2.4. 用户菜单
    • 2.5. 更新资料功能
    • 2.6. 管理好友功能
    • 2.7. 添加好友功能
    • 2.8. 删除好友功能
    • 2.9. 查看好友列表功能
    • 2.10. 发布动态功能
    • 后面代码太多了,我就不一 一分析了直接看功能展示吧👇
  • 三、功能展示
    • 3.1 用户端
      • 3.1.1 用户登录
      • 3.1.2 用户注册
      • 3.1.3 更新用户资料
      • 3.1.4 管理好友
        • 3.1.4.1 添加好友
        • 3.1.4.2 删除好友
        • 3.1.4.3 好友列表
      • 3.1.5 发布朋友圈
      • 3.1.6 查看并评论
    • 3.2 管理员
      • 3.2.1 查看所有用户
      • 3.2.2 删除用户
      • 3.2.3 查看所有动态
      • 3.2.4 删除动态


一、设计要求

基于一门高级语言,搭建一个简易平台,所使用的数据库可以是MySQL或其他合适的数据库。例如类似以下内容的社交平台,可基于自己理解做适当变动,也可以自行设计其他应用场景,逻辑自治即可。

用户端:

  • 用户端用户可以注册,初始化用户id和密码
  • 用户可以登录,并修改个人基本信息,如姓名、性别、出生日期、年龄
  • 用户可以搜索、添加、删除好友,并将好友分组管理
  • 用户可以发表、修改朋友圈(朋友圈有字数限制),记录朋友圈最后更新时间
  • 用户可以查看好友的朋友圈(包含最后更新时间、其他人的评论),并进行评论用户可以删除自己的朋友圈,在删除时该朋友圈相关评论将被自动同时删除

管理员端:

  • 管理员拥有管理员id和密码
  • 管理员可以登录,并修改个人基本信息
  • 管理员可以注销某用户,并删除系统中所有与用户有关的信息管理员不可浏览用户的个人基本信息,但可以浏览所有朋友圈,进行审核和删除

基于理论课所学习的数据库设计相关知识,为你的系统设计合适的表结构、完整性约束、视图等。包含简单的事务管理、触发器等功能,具体内容自行设计为实现的功能建立合理的插入、删除、修改、查询代码逻辑,并为可能出现的代码报错提供错误处理机制至少实现一种交互方式,可以只实现命令行交互分别创建一位用户和管理员,并在数据库中初始化部分数据,便于验收。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈


二、代码实现

2.1 创建数据库

将下面信息更改为数据库信息,并且保证数据表都已经提前创建好。

import pymysql
import sys

connection = pymysql.connect(host='127.0.0.1',
                             user='root',
                             password='root',
                             db='SocialNetwork',
                             charset='utf8mb4',
                             cursorclass=pymysql.cursors.DictCursor)

执行如下命令,提前把数据库创建好:

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

CREATE DATABASE SocialNetwork;

USE SocialNetwork;

-- 用户表
CREATE TABLE Users (
    user_id INT AUTO_INCREMENT PRIMARY KEY,
    # 略....
    name VARCHAR(50),
    gender ENUM('M', 'F', 'Other'),
    birth_date DATE,
    age INT
);

-- 好友关系表
CREATE TABLE Friends (
    user_id INT,
    # 略....
    PRIMARY KEY (user_id, friend_id)
);

-- 朋友圈表
CREATE TABLE Moments (
    moment_id INT AUTO_INCREMENT PRIMARY KEY,
    # 略....>👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

    FOREIGN KEY (user_id) REFERENCES Users(user_id)
);

-- 评论表
CREATE TABLE Comments (
    comment_id INT AUTO_INCREMENT PRIMARY KEY,
    # 略....
    FOREIGN KEY (user_id) REFERENCES Users(user_id)
);

2.2 用户登录

该函数实现用户登录功能,输入用户名和密码后,通过SQL查询匹配数据库中的用户信息。若匹配成功,则根据用户名判断是否为管理员,进入相应的菜单;否则,显示登录失败信息并返回主菜单。

def login():
    username = input("请输入用户名: ")
    password = input("请输入密码: ")
    try:
        with connection.cursor() as cursor:
            sql = "SELECT * FROM Users WHERE username = %s AND password = %s"
            # 略 ....
    except Exception as e:
        print(e)

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

这段代码实现了一个简单的社交平台应用,包括用户和管理员的登录、注册、资料更新、好友管理、动态发布与查看、管理员对用户和动态的管理等功能。以下是对各个模块的实现思路分析:

2.3. 注册功能

def register():
    username = input("请选择用户名: ")
    password = input("请选择密码: ")
    try:
        with connection.cursor() as cursor:
            # 略 ....
    except Exception as e:
        print("注册失败,错误: ", e)
        main_menu()

该函数实现用户注册功能,输入用户名和密码后,通过SQL插入操作将新用户信息保存到数据库。注册成功后返回主菜单,否则显示错误信息。

2.4. 用户菜单

def user_menu(user_id):
    print("\n======用户菜单======")
    print("1. 更新资料")
    print("2. 管理好友")
    # 略 ....>👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

该函数实现用户菜单,提供更新资料、管理好友、发布动态、查看并评论动态、注销等选项。根据用户输入选择相应的操作。

2.5. 更新资料功能

def update_profile(user_id):
    print("\n******更新资料******")
    name = input("请输入全名: ")
    # 略 ....

该函数实现更新用户资料的功能,通过SQL更新操作修改数据库中的用户信息。更新成功后返回用户菜单,否则显示错误信息。

2.6. 管理好友功能

def manage_friends(user_id):
    print("\n======管理好友======")
    print("1. 添加好友")
    print("2. 删除好友")
    # 略 ....

该函数实现管理好友的功能,提供添加好友、删除好友、查看好友列表、返回等选项。根据用户输入选择相应的操作。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

2.7. 添加好友功能

def add_friend(user_id):
    friend_name = input("请输入要添加的好友用户名: ")
    group_name = input("请输入该好友的分组名称: ")
    try:
        with connection.cursor() as cursor:
            # 略 ....

该函数实现添加好友的功能,通过SQL查询确定好友用户ID后,再通过SQL插入操作将好友关系保存到数据库。操作完成后返回管理好友菜单。

2.8. 删除好友功能

def remove_friend(user_id):
    friend_name = input("请输入要删除的好友用户名: ")
    try:
        with connection.cursor() as cursor:
            sql = "SELECT user_id FROM Users WHERE username = %s"
            cursor.execute(sql, (friend_name,))
            # 略 ....

该函数实现删除好友的功能,通过SQL查询确定好友用户ID后,再通过SQL删除操作移除好友关系。操作完成后返回管理好友菜单。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

2.9. 查看好友列表功能

def list_friends(user_id):
    try:
        with connection.cursor() as cursor:
            sql = "SELECT username FROM Users WHERE user_id IN (SELECT friend_id FROM Friends WHERE user_id = %s)"
            cursor.execute(sql, (user_id,))
            results = cursor.fetchall()
            # 略 ....

该函数实现查看好友列表的功能,通过SQL查询获取用户的所有好友并显示。操作完成后返回管理好友菜单。

2.10. 发布动态功能

def post_moment(user_id):
    content = input("请输入动态内容(最多300字符): ")
    if len(content) > 300:
        # 略 ....

该函数实现发布动态的功能,输入动态内容后,通过SQL插入操作将动态保存到数据库。发布成功后返回用户菜单,否则显示错误信息。

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

后面代码太多了,我就不一 一分析了直接看功能展示吧👇


三、功能展示

3.1 用户端

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

3.1.1 用户登录

在这里插入图片描述

3.1.2 用户注册

在这里插入图片描述

3.1.3 更新用户资料

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

3.1.4 管理好友

3.1.4.1 添加好友

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

3.1.4.2 删除好友

在这里插入图片描述

3.1.4.3 好友列表

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

3.1.5 发布朋友圈

在这里插入图片描述

3.1.6 查看并评论

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

3.2 管理员

在这里插入图片描述

3.2.1 查看所有用户

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

3.2.2 删除用户

在这里插入图片描述

3.2.3 查看所有动态

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

3.2.4 删除动态

在这里插入图片描述

👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “社交” 获取。👈👈👈

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1683659.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

python安装路径可以更改吗

Python3.5默认安装路径是当前用户的 AppData\.. 下 现在安装过程中默认是install just for me,这个会把python默认安装到AppData文件夹中,如果选了install for all users,就会默认安装到C盘根目录了。 python3.5 安装: 输入官网…

机器学习入门-sklearn

概述 机器学习定义是什么? 官方定义: 机器学习是人工智能核心,是使计算机具有智能的根本途径。(地位) 机器学习专门研究计算机怎样模拟或实现人类的学习行为(研究内容),以获取新的…

PyCharm控制台中文乱码,输出�¹���

问题:很离谱的一件事就是python控制台可以正常的输出中文,但在pycharm控制台中就是乱码。 解决方法:之前看他们一些文章说设置pycharm的文件编码,不管怎么改都没用。 只是设置第一张图中的内容无效 好了,打完收工~

uview1.0 u-form表单回显校验不通过

提交到后端的数据,回显后不做任何修改无法通过表单校验 原因,u-form表单校验的类型默认为string,但是后端返回的是integer类型,导致无法通过校验 解决,既然后端返回的是整数形,那么我们就将校验规则的type…

有没有软件可以监控电脑软件?监控电脑软件的系统

有没有软件可以监控电脑软件?监控电脑软件的系统 电脑软件如果不合规也会给企业带来安全危害,比如盗版软件,比如游戏软件耽误工作等,所以需要对电脑软件的监控。下面我将详细介绍几款代表性的电脑监控软件及其功能,帮…

vscode添加代办相关插件,提高开发效率

这里写目录标题 前言插件添加添加TODO Highlight安装TODO Highlight在项目中自定义需要高亮显示的关键字 TODO Tree安装TODO Tree插件 单行注释快捷键 前言 在前端开发中,我们经常会遇到一些未完成、有问题或需要修复的部分,但又暂时未完成或未确定如何处…

树的非递归遍历(层序)

层序是采用队列的方式来遍历的 就比如说上面这颗树 他层序的就是:1 24 356 void LevelOrder(BTNode* root) {Que q;QueueInit(&q);if (root){QueuePush(&q, root);}while (!QueueEmpty(&q)){BTNode* front QueueFront(&q);QueuePop(&q);print…

Flutter Text导致A RenderFlex overflowed by xxx pixels on the right.

使用Row用来展示两个Text的时候页面出现如下异常,提示"A RenderFlex overflowed by xxx pixels on the right." The following assertion was thrown during layout: A RenderFlex overflowed by 4.8 pixels on the right.The relevant error-causing widget was:…

存储+调优:存储-Cloud

存储调优:存储-Cloud Master Server 配置: IP192.168.1.254 useradd mfs tar zxf mfs-1.6.11.tar.gz.gz cd mfs-1.6.11 ./configure --prefix/usr --sysconfdir/etc --localstatedir/var/lib --with-default-usermfs --with-default-groupmfs --disabl…

机器学习之决策树算法

使用决策树训练红酒数据集 完整代码: import numpy as np import matplotlib.pyplot as plt from matplotlib.colors import ListedColormap from sklearn import tree, datasets from sklearn.model_selection import train_test_split# 准备数据,这里…

安装pip install xmind2image失败,4种安装pip install xmind2image在temunx高级终端的失败,却又意外发现

~ $ ~ $ ![在这里插入图片描述](https://img-blog.csdnimg.cn/b59cbb49c3e14a3bbec5675164a14009.png)#!/bin/bash # 创建一个新的空白XMind文件 xmind_dir ( m k t e m p − d ) x m i n d f i l e n a m e ′ t e s t . x m i n d ′ x m i n d p a t h " (mktemp -d…

github设置项目分类

https://www.php.cn/faq/541957.html https://docs.github.com/zh/repositories/working-with-files/managing-files/creating-new-files

在数据中心网络中隔离大象流

1000 条短突发中混入几条大象流将严重影响短突发 p99 latency,造成抖动。这个我在 隔离网络流以优化网络 论证过了,还有另一种更直观的理解方式: 规模差异越大,算术均值越偏离中位数,即算术均值的分位数越高。 可以…

web4.0-元宇宙虚拟现实

互联网一直在不断演变和改变我们的生活方式,从Web逐渐 1.0时代的静态网页到Web 2.0时代的社会性和内容制作,再从Web逐渐 在3.0阶段,互联网发展一直推动着大家时代的发展。如今,大家正站在互联网演化的新起点上,迈入Web…

两步将 CentOS 6.0 原地升级并迁移至 RHEL 7.9

《OpenShift / RHEL / DevSecOps 汇总目录》 说明 本文介绍如何将一个 CentOS 6.0 的系统升级并转换迁移到 RHEL 7.9。 本文是《在离线环境中将 CentOS 7.X 原地升级并迁移至 RHEL 7.9》阶进篇。 所有被测软件的验证操作可参见上述前文中对应章节的说明。 准备 CentOS 6.…

紫光同创PGL22G开发板|盘古22K开发板,国产FPGA开发板,接口丰富

盘古22K开发板是基于紫光同创Logos系列PGL22G芯片设计的一款FPGA开发板,全面实现国产化方案,板载资源丰富,高容量、高带宽,外围接口丰富,不仅适用于高校教学,还可以用于实验项目、项目开发,一板…

爆火!开源多模态大模型在手机端进行本地部署!

节前,我们组织了一场算法岗技术&面试讨论会,邀请了一些互联网大厂朋友、今年参加社招和校招面试的同学。 针对大模型& AIGC 技术趋势、大模型& AIGC 落地项目经验分享、新手如何入门算法岗、该如何准备面试攻略、面试常考点等热门话题进行了…

神经网络模型结构和参数可视化

神经网络模型结构和参数可视化 一、前言二、Netron2.1Netron简介2.2TensorFlow、Keras、Caffe模型文件实测结果2.3PyTorch、scikit-learn模型文件实测结果 三、NN-SVG四、Netscope五、PlotNeuralNet六、Graphviz七、总结参考文档 一、前言 在神经网络的某些应用场景中&#xf…

[STM32-HAL库]AS608-指纹识别模块-STM32CUBEMX开发-HAL库开发系列-主控STM32F103C8T6

目录 一、前言 二、详细步骤 1.光学指纹模块 2.配置STM32CUBEMX 3.程序设计 3.1 输出重定向 3.2 导入AS608库 3.3 更改端口宏定义 3.4 添加中断处理部分 3.5 初始化AS608 3.6 函数总览 3.7 录入指纹 3.8 验证指纹 3.9 删除指纹 3.10 清空指纹库 三、总结及资源 一、前言 …

线程的概念和控制

文章目录 线程概念线程的优点线程的缺点线程异常线程用途理解虚拟地址 线程控制线程的创建线程终止线程等待线程分离封装线程库 线程概念 什么是线程? 在一个程序里的一个执行路线就叫做线程(thread)。更准确的定义是:线程是“一…