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


👉博__主👈:米码收割机

👉技__能👈:C++/Python语言

👉公众号👈:测试开发自动化【获取源码+商业合作】

👉荣__誉👈:阿里云博客专家博主、51CTO技术博主

👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。


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


目录

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

一、设计要求

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

用户端:

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

管理员端:

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

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

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


二、代码实现

2.1 创建数据库

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

python 复制代码
import pymysql
import sys

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

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

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

python 复制代码
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查询匹配数据库中的用户信息。若匹配成功,则根据用户名判断是否为管理员,进入相应的菜单;否则,显示登录失败信息并返回主菜单。

python 复制代码
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. 注册功能

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

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

2.4. 用户菜单

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

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

2.5. 更新资料功能

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

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

2.6. 管理好友功能

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

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

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

2.7. 添加好友功能

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

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

2.8. 删除好友功能

python 复制代码
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. 查看好友列表功能

python 复制代码
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. 发布动态功能

python 复制代码
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 删除动态

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

相关推荐
lyrhhhhhhhh4 分钟前
Spring 框架 JDBC 模板技术详解
java·数据库·spring
noravinsc1 小时前
django中用 InforSuite RDS 替代memcache
后端·python·django
好吃的肘子1 小时前
Elasticsearch架构原理
开发语言·算法·elasticsearch·架构·jenkins
喝醉的小喵1 小时前
【mysql】并发 Insert 的死锁问题 第二弹
数据库·后端·mysql·死锁
胡耀超1 小时前
霍夫圆变换全面解析(OpenCV)
人工智能·python·opencv·算法·计算机视觉·数据挖掘·数据安全
doupoa2 小时前
Fabric 服务端插件开发简述与聊天事件监听转发
运维·python·fabric
nlog3n2 小时前
Go语言交替打印问题及多种实现方法
开发语言·算法·golang
kaixin_learn_qt_ing2 小时前
Golang
开发语言·后端·golang
ddd...e_bug2 小时前
Shell和Bash介绍
开发语言·bash
How_doyou_do2 小时前
备战菊厂笔试4
python·算法·leetcode