前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python终端美化——rich

Python终端美化——rich

作者头像
一只大鸽子
发布2024-03-25 14:16:54
2630
发布2024-03-25 14:16:54
举报
文章被收录于专栏:Python基础、进阶与实战

图1 rich logo

rich简介

rich是一个用于美化终端的Python库,下面这幅图展示了它的主要功能。

图2 rich介绍

rich的文档[1]提供了详细的说明:

Rich 是一个 Python 库,可以为您在终端中提供富文本和精美格式。 Rich 的 API 让在终端输出颜色和样式变得很简单。此外,Rich 还可以绘制漂亮的表格、进度条、markdown、语法高亮的源代码以及栈回溯信息(tracebacks)等——开箱即用。

安装python -m pip install rich

预览:在终端运行python -m rich,可以看到图2的效果。

rich常用功能

下面根据How to Use the Rich Library with Python[2],介绍一下rich的常用功能。

1. 替代print

可以使用richprint函数替代内置的print

代码语言:javascript
复制
from rich import print

print("Hello, [bold magenta]World[/bold magenta]!", ":vampire:", locals())

rich 与 内置print

2. 在交互命令行(REPL)使用

代码语言:javascript
复制
>>> from rich import pretty
>>> pretty.install()

>>> locals()

3. 控制终端格式

为了完全控制终端格式,Rich 提供了一个 Console 类。

代码语言:javascript
复制
from rich.console import Console

console = Console()

def merge_dict(dict_one, dict_two):
    merged_dict = dict_one | dict_two
    console.log(merged_dict, log_locals=True)

merge_dict({'id': 1}, {'name': 'Ashutosh'})

我们创建了一个Console对象,然后使用log方法打印了一个合并后的字典。log方法和print方法类似,但是添加了一些帮助调试的信息,例如我们用log_locals打印局部变量。Console提供了很多功能,如控制终端的颜色、样式、大小以及输出不同内容。详细的说明可以参考Console API[3]

4. 使用inspect检查对象

代码语言:javascript
复制
from rich import inspect
import rich

inspect(rich)

5. 使用Tree显示文件系统等树状结构

Tree

代码语言:javascript
复制
from rich.tree import Tree
from rich import print as rprint


tree = Tree("Family Tree")
tree.add("Mom")
tree.add("Dad")
tree.add("Brother").add("Wife")
tree.add("[red]Sister").add("[green]Husband").add("[blue]Son")

rprint(tree)

6. 显示进度条

进度条

代码语言:javascript
复制
from rich.progress import track
from time import sleep

def process_data():
    sleep(0.02)

for _ in track(range(100), description='[green]Processing data'):
    process_data()

如果我们想记录特定任务完成执行的时间,我们可以用console.status

代码语言:javascript
复制
from rich.console import Console
from time import sleep

console = Console()

data = [1, 2, 3, 4, 5]
with console.status("[bold green]Fetching data...") as status:
    while data:
        num = data.pop(0)
        sleep(1)
        console.log(f"[green]Finish fetching data[/green] {num}")

    console.log(f'[bold][red]Done!')

如果需要在显示中执行多个任务或想要自定义进度显示中的列,则可以直接使用 Progress 类。创建 Progress 对象后,使用add_task() 添加任务,使用 update_progress()更新进度。

多个进度条

代码语言:javascript
复制
import time

from rich.progress import Progress

with Progress() as progress:

    task1 = progress.add_task("[red]Downloading...", total=100)
    task2 = progress.add_task("[green]Processing...", total=100)
    task3 = progress.add_task("[cyan]Installing...", total=100)

    while not progress.finished:
        progress.update(task1, advance=0.9)
        progress.update(task2, advance=0.6)
        progress.update(task3, advance=0.3)
        time.sleep(0.02)

Progress 类旨在用作上下文管理器,自动启动和停止进度显示。

7. 显示列

Rich 可以将文本(或其他Rich renderables对象)呈现 Columns中。

Columns

代码语言:javascript
复制
import json
from urllib.request import urlopen

from rich.console import Console
from rich.columns import Columns
from rich.panel import Panel

def get_content(user):
    """Extract text from user dict."""
    country = user["location"]["country"]
    name = f"{user['name']['first']} {user['name']['last']}"
    return f"[b]{name}[/b]\n[yellow]{country}"

console = Console()

users = json.loads(urlopen("https://randomuser.me/api/?results=30").read())["results"]
user_renderables = [Panel(get_content(user), expand=True) for user in users]
console.print(Columns(user_renderables))

8. 显示表格

Rich的Table类提供了多种将表格数据呈现到终端的方法。Table类具有 add_column()add_row()方法,用于将列和行分别添加到Table中。

Table

代码语言:javascript
复制
from rich.console import Console
from rich.table import Table

table = Table(title="Todo List")

table.add_column("S. No.", style="cyan", no_wrap=True)
table.add_column("Task", style="magenta")
table.add_column("Status", justify="right", style="green")

table.add_row("1", "Buy Milk", "✅")
table.add_row("2", "Buy Bread", "✅")
table.add_row("3", "Buy Jam", "❌")

console = Console()
console.print(table)
引用链接

[1] rich的文档: https://github.com/textualize/rich/blob/master/README.cn.md [2] How to Use the Rich Library with Python: https://www.freecodecamp.org/news/use-the-rich-library-in-python/ [3] Console API: https://rich.readthedocs.io/en/latest/console.html

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-03-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 一只大鸽子 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • rich简介
  • rich常用功能
    • 1. 替代print
      • 2. 在交互命令行(REPL)使用
        • 3. 控制终端格式
          • 4. 使用inspect检查对象
            • 5. 使用Tree显示文件系统等树状结构
              • 6. 显示进度条
                • 7. 显示列
                  • 8. 显示表格
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档