使用 rye 管理 python 依赖

rye 是使用 rust 实现的一个项目和包管理解决方案。

配置 pip 源

vim ~/.pip/pip.conf

[global]
index-url = http://mirrors.cloud.tencent.com/pypi/simple/
trusted-host = mirrors.cloud.tencent.com

安装 rye

cargo install --git https://github.com/mitsuhiko/rye rye

配置 rye 环境变量

# ZSH
echo 'source "$HOME/.rye/env"' >> ~/.zshrc
source ~/.zshrc

# BASH
echo 'source "$HOME/.rye/env"' >> ~/.bashrc
source ~/.zshrc

# UNIX Shells
echo 'source "$HOME/.rye/env"' >> ~/.profile
source ~/.profile

# Windows
$USERPROFILE%\.rye\shims 加入到系统的 PATH 环境变量中

升级 rye 已有版本

rye self update

安装 python 依赖

# rye pin 命令不会立即改变 Python 的版本,仅修改配置文件 .python-version,在 rye sync 执行时才进行实际的修改。
rye pin 3.10
# 可以使用 rye toolchain 来查看、拉取和删除 Python 版本。
# 用来显示所有已经安装的 Python 版本:
rye toolchain list
# 列出所有可下载的 Python 版本
# 注意已经下载的 Python 版本不在这个输出中
rye toolchain list --include-downloadable
# 第一次执行,会下载一个单独的 Python 解释器,放置到 $HOME/.rye/py 目录下,链接到项目的 .venv 目录下,因此同一个 Python 版本在磁盘上只有一份.
# 然后安装依赖,刷新 .lock 结尾的文件
# requirements.lock 和 requirements-dev.lock
rye sync --verbose

安装 pre-commit

rye install pre-commit
pre-commit install --allow-missing-config
pre-commit install --hook-type commit-msg --allow-missing-config

配置 .pre-commit-config.yaml

default_stages: [commit]
repos:
  - repo: https://github.com/asottile/pyupgrade
    rev: v3.16.0
    hooks:
      - id: pyupgrade
  - repo: https://github.com/pre-commit/pre-commit-hooks
    rev: v4.6.0
    hooks:
    - id: check-merge-conflict
  - repo: https://github.com/psf/black
    rev: 24.4.2
    hooks:
      - id: black
        language_version: python3.10
        args: [ --config=pyproject.toml ]
  - repo: https://github.com/pycqa/isort
    rev: 5.13.2
    hooks:
      - id: isort
        name: isort
        additional_dependencies: [ "toml" ]
        args: [ --settings-path=pyproject.toml ]
  - repo: https://github.com/pycqa/flake8
    rev: 7.1.0
    hooks:
    - id: flake8
      additional_dependencies: [flake8-docstrings]

配置 .flake8

[flake8]
ignore =
    W503,
    E203,
    D100,
    D101,
    D102,
    D103,
    D205,
    D400,

exclude =
    .tox,
    .git,
    __pycache__,
    build,
    dist,
    *.pyc,
    *.egg-info,
    .cache,
    .eggs,

max-line-length=120
max-complexity=25
format=pylint
show_source=False
statistics=True
count=True

安装 black

rye install black
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要安装PyCharm和MySQL数据库。然后,按照以下步骤操作: 1. 在MySQL数据库中创建一个名为“library”的数据库。 2. 在PyCharm中创建一个名为“library”的项目。 3. 安装PyMySQL库,使用以下命令在PyCharm的终端中进行安装: ``` pip install PyMySQL ``` 4. 创建一个名为“db.py”的Python文件,并编写用于连接到MySQL数据库的代码: ```python import pymysql class Database: def __init__(self): self.host = "localhost" self.user = "root" self.password = "your_password" self.db = "library" self.port = 3306 def connect(self): try: self.connection = pymysql.connect(host=self.host, user=self.user, password=self.password, db=self.db, port=self.port, cursorclass=pymysql.cursors.DictCursor) self.cursor = self.connection.cursor() print("Connection successful") except Exception as e: print("Connection refused: ", e) ``` 注意将“your_password”替换为你的MySQL数据库密码。 5. 创建一个名为“main.py”的Python文件,并编写用于实现图书馆借阅系统的代码。 例如,你可以创建一个名为“Book”类,并在类中定义以下方法: ```python class Book: def __init__(self, title, author, publisher, isbn): self.title = title self.author = author self.publisher = publisher self.isbn = isbn def add_book(self): query = "INSERT INTO books (title, author, publisher, isbn) VALUES (%s, %s, %s, %s)" values = (self.title, self.author, self.publisher, self.isbn) db.cursor.execute(query, values) db.connection.commit() def delete_book(self, id): query = "DELETE FROM books WHERE id = %s" db.cursor.execute(query, id) db.connection.commit() def update_book(self, id): query = "UPDATE books SET title = %s, author = %s, publisher = %s, isbn = %s WHERE id = %s" values = (self.title, self.author, self.publisher, self.isbn, id) db.cursor.execute(query, values) db.connection.commit() @staticmethod def view_books(): query = "SELECT * FROM books" db.cursor.execute(query) results = db.cursor.fetchall() for book in results: print(book) ``` 这些方法用于添加、删除、更新和查看图书馆中的书籍。 6. 在“main.py”文件中,创建一个名为“db”的Database类实例,并调用其“connect”方法以连接到MySQL数据库。 ```python if __name__ == "__main__": db = Database() db.connect() ``` 7. 在“main.py”文件中,编写使用Book类的代码来实现图书馆借阅系统的操作,例如: ```python if __name__ == "__main__": db = Database() db.connect() book1 = Book("The Great Gatsby", "F. Scott Fitzgerald", "Scribner", "978-0743273565") book1.add_book() book2 = Book("To Kill a Mockingbird", "Harper Lee", "J. B. Lippincott & Co.", "978-0446310789") book2.add_book() Book.view_books() book1.title = "The Catcher in the Rye" book1.update_book(1) Book.view_books() book2.delete_book(2) Book.view_books() ``` 这些代码将添加两本书,查看所有书籍,更新第一本书的标题,删除第二本书,并再次查看所有书籍。 8. 运行“main.py”文件,以查看图书馆借阅系统的操作是否成功。 请注意,在实际应用中,你需要添加更多功能和验证,例如添加用户、实现借书和还书等。此外,出于安全原因,你还应该使用密码保护数据库,并对用户输入进行验证和过滤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值