python为什么不能以数字开头_python变量为什么不能以数字开头
任何事情只要有人規(guī)定成文了,必定有其原因所在,也就是有其合理性所在。
Python變量命名規(guī)則(推薦學(xué)習(xí):Python視頻教程)
變量名只能包含字母、數(shù)字和下劃線。變量名可以字母或下劃線開(kāi)頭,但不能以數(shù)字開(kāi)頭,例如,可將變量命名為message_1,但不能將其命名為1_message。
變量名不能包含空格,但可使用下劃線來(lái)分隔其中的單詞。例如,變量名greeting_message可行,但變量名greeting message會(huì)引發(fā)錯(cuò)誤。
不要將Python關(guān)鍵字和函數(shù)名用作變量名,即不要使用Python保留用于特殊用途的單詞,如print。
變量名應(yīng)既簡(jiǎn)短又具有描述性。例如,name比n好,student_name比s_n好,name_length比length_of_persons_name好。
慎用小寫(xiě)字母l和大寫(xiě)字母O,因給他們可能被人錯(cuò)看成數(shù)字1和0;
注意:應(yīng)使用小寫(xiě)的Python變量名。在變量名中使用大寫(xiě)字母雖然不會(huì)導(dǎo)致錯(cuò)誤,但避免使用大寫(xiě)字母是個(gè)不錯(cuò)的注意。
那么它為什么不能以數(shù)字開(kāi)頭呢?這應(yīng)該要從編譯原理的角度來(lái)解釋了吧。
這是我今天在做腳本解析時(shí)突然想到的。先來(lái)說(shuō)明一下我們的這個(gè)語(yǔ)法解析工具,要解析的腳本很簡(jiǎn)單,只包括了&,|,~,=,!=,()和{}等操作符。開(kāi)始時(shí)采用了編譯原理的那一套,畫(huà)NFA、DFA,找出狀態(tài)然后再寫(xiě)詞法分析生成Token,接著語(yǔ)法分析將生成的Token根據(jù)語(yǔ)義生成語(yǔ)法樹(shù),最后求值。后來(lái)想一想,這個(gè)腳本很簡(jiǎn)單只需要一個(gè)一個(gè)字符判斷遇到不同類(lèi)型的字符就進(jìn)入到不同的子函數(shù)中進(jìn)行處理,同時(shí)完成詞法解析和語(yǔ)法分析以及求值的過(guò)程。不過(guò)無(wú)論使用那種方法都需要根據(jù)讀入的字符來(lái)判斷當(dāng)前進(jìn)入到哪個(gè)Token里了,這就是問(wèn)題的關(guān)鍵所在。
為什么說(shuō)判斷字符屬于哪個(gè)Token是關(guān)鍵呢?
假設(shè)我們?nèi)∠袅俗兞棵x中不能以數(shù)字開(kāi)頭的限制,這時(shí)當(dāng)詞法分析器進(jìn)入到一個(gè)Token分析的起始狀態(tài)時(shí),如果讀取的第一個(gè)字符為數(shù)字,那么詞法分析器是無(wú)法判斷它當(dāng)前要分析的這個(gè)Token是變量名還是數(shù)字常量了。好,如果你說(shuō)分析器可以根據(jù)后面的字符來(lái)判斷的話,那么如果下一個(gè)字符為字母,那么很容易就判斷出當(dāng)前Token屬于變量名(我們暫且忽略保留關(guān)鍵字),但是當(dāng)如果接下來(lái)的字符全都是數(shù)字那怎么辦?分析器將無(wú)法判斷,因?yàn)樽兞棵亩x中允許數(shù)字的存在。
呵呵,上面也許說(shuō)的比較繞口難于理解,用句簡(jiǎn)單的話來(lái)講就是:當(dāng)分析"123"這個(gè)字符串的時(shí)候,如果變量名允許第一個(gè)字符為數(shù)字,分析器就不知道“123”該是數(shù)值常量還是變量名了。
更多Python相關(guān)技術(shù)文章,請(qǐng)?jiān)L問(wèn)Python教程欄目進(jìn)行學(xué)習(xí)!
總結(jié)
以上是生活随笔為你收集整理的python为什么不能以数字开头_python变量为什么不能以数字开头的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python地理数据处理 下载_pyth
- 下一篇: python获取用户输入的数字_Pyth