Flutter + FastAPI 30天速成计划自用并实践-第7天

Day 7 详细学习计划:内容导入脚本开发

学习目标

  • 创建批量内容导入脚本
  • 学习自动化内容管理
  • 完善后端功能

好,在day6的基础上添加一个脚本,然后运行这个脚本就能将学习记录导入到数据库中了

创建一个advanced_import.py脚本,这个脚本可以将markdown文件,导入到数据库中,在fastapi接口中可以用get方法查看到

python 复制代码
import argparse
from datetime import datetime
from sqlmodel import Session
from database import engine, create_db_and_tables
from models.article import Article

def import_articles(file_path: str, clear_existing: bool = False):
    """导入文章的通用函数"""
    # 创建数据库表
    create_db_and_tables()
    
    # 读取Markdown文件
    with open(file_path, 'r', encoding='utf-8') as f:
        content = f.read()
    
    # 解析Markdown文件获取标题
    lines = content.split('\n')
    title = "默认标题"
    for line in lines:
        if line.startswith('# '):
            title = line[2:]  # 移除 "# " 前缀
            break
    
    # 使用文件名(不含扩展名)作为备选标题
    if title == "默认标题":
        import os
        title = os.path.splitext(os.path.basename(file_path))[0]
    
    # 导入文章
    with Session(engine) as session:
        # 如果需要清除现有数据
        if clear_existing:
            # 删除所有现有文章
            articles = session.query(Article).all()
            for article in articles:
                session.delete(article)
            session.commit()
            print("已清除现有文章")
        
        # 创建新文章对象
        article = Article(
            title=title,
            content=content,
            created_at=datetime.now()
        )
        
        # 添加到数据库
        session.add(article)
        session.commit()
        session.refresh(article)
        print(f"成功导入文章: {article.title}")

def main():
    parser = argparse.ArgumentParser(description='导入文章到数据库')
    parser.add_argument('file', help='要导入的Markdown文件路径')
    parser.add_argument('--clear', action='store_true', help='导入前清除现有数据')
    
    args = parser.parse_args()
    
    import_articles(args.file, args.clear)

if __name__ == "__main__":
    # 为了测试方便,可以暂时使用固定路径
    import_articles('./第七天的内容.md', True)
    # main()  # 正常情况下使用命令行参数

上面我测试了下将第七天的内容md文件导入到数据库中

使用get请求访问接口,就可以看到导入的md文件内容了
http://127.0.0.1:8000/api/v1/articles/

在浏览器中直接输入网址也可以,默认浏览器是识别的get方法,所以可以访问

结果就是
[{"title":"Day 7 详细学习计划:内容导入脚本开发","content":"# Day 7 详细学习计划:内容导入脚本开发......

到今天后端就先这样了,明天开始学习flutter,

相关推荐
m0_7162550012 分钟前
批处理一道例题+答案解析+批处理知识点总结 | 批处理高频易错场景 + 正确写法对照表
数据库·oracle
俺不要写代码33 分钟前
数据库:DML
数据库·oracle
MonkeyKing34 分钟前
Flutter列表性能极致优化:从卡顿到丝滑
flutter·dart
IntMainJhy41 分钟前
「Flutter三方库sqflite的鸿蒙化适配与实战指南:从入门到踩坑的本地数据库开发全记录」
数据库·flutter·华为·信息可视化·数据库开发·harmonyos
Irene19911 小时前
Oracle 中:为什么 from 子查询后面需要一个别名
数据库·oracle
梦想不只是梦与想2 小时前
flutter中 safeArea组件
flutter·safearea
杨云龙UP2 小时前
Oracle数据库启动失败:ORA-29701、ORA-01565、ORA-17503故障处理记录_20260429
linux·运维·数据库·oracle·centos
懒铭心3 小时前
Oracle 19c 备份与恢复
oracle
于歌8523 小时前
Oracle批处理操作方法
数据库·oracle