<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          醒醒!Python已經(jīng)支持中文變量名啦!

          共 2092字,需瀏覽 5分鐘

           ·

          2021-01-13 15:34

          ?△點擊上方Python貓”關注 ,回復“1”領取電子書

          作者:豌豆花下貓

          來源:Python貓

          最近,我在翻閱兩本比較新的 Python 書籍時,發(fā)現(xiàn)它們都犯了一個嚴重的低級錯誤!

          這兩本書分別是《Python編程:從入門到實踐》和《父與子的編程之旅》,它們都是暢銷書,都在 2020 年 10 月出了新版本,都使用 Python3.7+ 版本的語法。

          然而,在關于變量的命名規(guī)則部分,它們犯下了一樣的錯誤,即還在使用 Python2 時代的那套說辭,誤以為命名僅僅支持“字母、數(shù)字和下劃線”的組合。

          事實上,Python3.x 已經(jīng)支持全面 Unicode 編碼,比如支持使用中文作為變量名。

          >>>?姓名?="Python貓"
          >>>?print(f"我是{姓名},歡迎關注!")
          我是Python貓,歡迎關注!

          由于我手頭上沒有其它樣本,所以,我不確定有多少新版的書籍還在使用老的規(guī)則。但是,翻譯類的書籍大概率都會有這樣的問題,另外,有些不嚴謹?shù)膰鴥葧?,也可能因為借鑒了過時的材料而犯錯。

          如此一來,恐怕有些新接觸 Python 的同學,就會形成錯誤的認識。雖然這可能不會造成嚴重的問題,但是它終歸是一個應該避免而且很容易就能避免的問題。

          因此,我覺得這個話題值得聊一聊。

          在編程語言中有一個很常見的概念,即標識符(identifier),通常又會稱之為名字(name),用于標識出變量、常量、函數(shù)、類、符號等實體的名字。

          在定義標識符時,有一些必須要考慮的基本規(guī)則:
          • 它可以由哪些字符組成?

          • 它是否區(qū)分大小寫?(即大小寫敏感)

          • 它是否允許出現(xiàn)某些特殊的單詞?(即關鍵字/保留字)

          對于第一個問題,大多數(shù)的編程語言在早期版本都遵循這條規(guī)則:標識符由字母、數(shù)字和下劃線組成,并且不能以數(shù)字為開頭。 少數(shù)的編程語言有例外,還支持使用$、@、%等特殊符號(例如PHP、Ruby、Perl等等)。

          Python 的早期版本,確切地說是 3.0 之前的版本,就遵循以上的命名規(guī)則。下面是官方文檔中的描述:

          identifier?::=??(letter|"_")?(letter?|?digit?|?"_")*
          letter?????::=??lowercase?|?uppercase
          lowercase??::=??"a"..."z"
          uppercase??::=??"A"..."Z"
          digit??????::=??"0"..."9"
          出處:https://docs.python.org/2.7/reference/lexical_analysis.html#identifiers

          但是,這條規(guī)則從 3.0 版本起,就被打破了。最新的官方文檔已經(jīng)變成了這樣:

          出處:https://docs.python.org/3/reference/lexical_analysis.html#identifiers

          隨著互聯(lián)網(wǎng)的普及,各國語言進入了國際化的語境中,編程語言也與時俱進地增長了對國際化的訴求。

          Unicode(譯作統(tǒng)一碼、萬國碼)編碼標準在 1994 年發(fā)布,隨后逐步被主流的編程語言所接納。到目前為止,至少有 73 種編程語言支持 Unicode 變量名(數(shù)據(jù)依據(jù):https://rosettacode.org/wiki/Unicode_variable_names)。

          2007 年,當 Python 正在設計劃時代的 3.0 版本時,官方也考慮了對 Unicode 編碼的支持,于是,誕生了重要的《PEP 3131 -- Supporting Non-ASCII Identifiers》。

          出處:https://www.python.org/dev/peps/pep-3131

          事實上,除了我們最關心的中文,Unicode 字符集還包含非常非常多的內容。

          在對變量命名時,下面這些用法都是可行的(謹慎使用,如若被打,本貓概不負責……):

          >>>?ψ?=?1
          >>>?Δ?=?1
          >>>??_??=?"hello"

          綜上所述,某些 Python 書籍中關于變量命名規(guī)則的內容已經(jīng)過時了,不應該被其所誤導!

          Python 3 作為一門面向現(xiàn)代化/國際化的語言,對于 Unicode 編碼有很好的支持。至于該不該在項目中使用中文給標識符命名,那就是另外的問題啦……

          Python貓技術交流群開放啦!群里既有國內一二線大廠在職員工,也有國內外高校在讀學生,既有十多年碼齡的編程老鳥,也有中小學剛剛入門的新人,學習氛圍良好!想入群的同學,請在公號內回復『交流群』,獲取貓哥的微信(謝絕廣告黨,非誠勿擾?。?/span>~

          近期熱門文章推薦:

          Python 協(xié)程的本質?原來也不過如此
          Python 函數(shù)為什么會默認返回 None?
          漫畫:如何分析運行中的 Python 程序?
          Python之父重回決策層,未來如何發(fā)展?

          瀏覽 54
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  超碰人人爱人人操 | 91久久婷婷国产麻豆精品电影.co | 三级片电影麻豆 | 蜜桃成人中文字幕 | 青娱乐在线国产视频 |