您的位置:首頁技術文章
文章詳情頁

ubuntu - Python3.x的中文字符在Linux下面的占位問題?

瀏覽:103日期:2022-08-30 11:56:58

問題描述

運行環境:python3.x + ubuntu

def print_table(table): max_width = 0 # 取table中最長元素 for x in table:if len(x) > col_width: max_width = len(x) max_width = max_width * 2 for x in table:print(’{:{}}’.format(x, max_width) + ’|’)

英文可以正常對齊:

>>> en = [’hello’, ’world’, ’hi’, ’bug’]>>> print_table(en)hello |world |hi|bug |

中文無法無法正常對齊:

>>> ch = [’上?!? ’北京’, ’黑龍江’, ’烏魯木齊’]>>> print_table(ch)上海 |北京 |黑龍江 |烏魯木齊 |

請問這是什么原因?我觀察了一下好像是中文字符在終端下面的輸出都是占用了兩個空格,但是英文只占用了一個空格。如果是這樣,有什么好的解決方法?

問題解答

回答1:

更換終端的字體,更換為等寬字體,像比較養眼的Consolas,Adobe 的開源字體 Source Code Pro...

回答2:

Unicode字符串算長度是按照字符數而不是“顯示出來的寬度”,一個漢字和一個西文都算1的,所以對不齊。可以用額外的wcwidth包來計算字符占用的格子數。

回答3:

解決辦法是使用中文全角空格填充,應該對你有幫助。

>>> print('{:{space}<6s}'.format('上海', space=chr(12288))+’|’)上海|>>> print('{:{space}<6s}'.format('北京', space=chr(12288))+’|’)北京|>>> print('{:{space}<6s}'.format('黑龍江', space=chr(12288))+’|’)黑龍江 |>>> print('{:{space}<6s}'.format('烏魯木齊', space=chr(12288))+’|’)烏魯木齊|>>> 回答4:

segmentfault.com/q/1010000008288733/a-1020000008291692

標簽: Python 編程
相關文章:
国产综合久久一区二区三区