python(71) :

1.效果

bash 复制代码
████████████████████
█                  █
█   Hello World    █
█                  █
████████████████████


████████████████████
█                  █
█  你好,Python!  █
█                  █
████████████████████


████████████████████████████████████████████████████████
█                                                      █
█ 这是一段比较长的测试文本,用来验证自动适配宽度的效果      █
█                                                      █
████████████████████████████████████████████████████████

这是csdn显示异常, 终端打印是对其了的

2.border_display.py

python 复制代码
# border_display.py
def get_display_width(s):
    """
    计算字符串的显示宽度(中文字符占2个宽度,英文字符占1个)
    
    Args:
        s (str): 需要计算宽度的字符串
        
    Returns:
        int: 字符串的显示宽度
    """
    width = 0
    for c in s:
        if ord(c) > 127:  # 中文字符的Unicode编码大于127
            width += 2
        else:
            width += 1
    return width


def display_with_border(text, min_width=20, max_width=120):
    """
    将指定文本用边框包裹展示,边框宽度自动适配文本长度
    
    Args:
        text (str): 需要展示的文本内容
        min_width (int): 边框的最小宽度(避免内容过短时边框太窄)
        max_width (int): 边框的最大宽度(避免内容过长时边框太宽)
    """
    # 计算文本的实际显示宽度
    text_width = get_display_width(text)
    
    # 自动计算边框总宽度:取文本宽度+4(左右各留2个空格)、最小宽度的较大值,且不超过最大宽度
    SEPARATOR_WIDTH = min(max(text_width + 4, min_width), max_width)
    inner_width = SEPARATOR_WIDTH - 2  # 边框内部可显示的宽度
    
    # 生成带边框的内容
    print(f"\n{'█' * SEPARATOR_WIDTH}")
    print(f"█{' ' * inner_width}█")
    
    # 计算文本左右的填充空格数,让文本居中
    padding = (inner_width - text_width) // 2
    print(f"█{' ' * padding}{text}{' ' * (inner_width - text_width - padding)}█")
    
    print(f"█{' ' * inner_width}█")
    print(f"{'█' * SEPARATOR_WIDTH}\n")


# 模块自测代码(仅在直接运行该文件时执行)
if __name__ == "__main__":
    # 测试不同内容的展示效果
    display_with_border("Hello World")
    display_with_border("你好,Python!")
    display_with_border("这是一段比较长的测试文本,用来验证自动适配宽度的效果")
相关推荐
arvin_xiaoting1 小时前
OpenClaw学习总结_I_核心架构_8:SessionPruning详解
前端·chrome·学习·系统架构·ai agent·openclaw·sessionpruning
工程师老罗3 小时前
Image(图像)的用法
java·前端·javascript
早點睡3903 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-swiper
javascript·react native·react.js
FreakStudio3 小时前
不用装软件!这款MicroPython浏览器 IDE :让你在手机上也能调试树莓派 Pico
python·单片机·嵌入式·电子diy·tinyml
jump_jump3 小时前
深入 JavaScript Iterator Helpers:从 API 到引擎实现
javascript·性能优化
swipe4 小时前
把 JavaScript 原型讲透:从 `[[Prototype]]`、`prototype` 到 `constructor` 的完整心智模型
前端·javascript·面试
问道飞鱼4 小时前
【前端知识】React 组件生命周期:从底层原理到实践场景
前端·react.js·前端框架·生命周期
m0_743470374 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
Dxy12393102164 小时前
JS发送请求的方法详解
开发语言·javascript·ecmascript
CHU7290354 小时前
定制专属美丽时刻:美容预约商城小程序的贴心设计
前端·小程序