S7h和WINCC變量命名規(guī)范
知乎上說,這是一個嚴(yán)肅的問題。
嗯,確實這也是一個長久以來困擾我們所有工控人的問題。
我們可以參考下IT界的變量命名規(guī)范,如:如何優(yōu)雅地為程序中的變量和函數(shù)命名?
然后我們也可以從中了解到一些匈牙利命名法、google風(fēng)格等稱謂,但即便你把這些規(guī)則全讀懂了,也會發(fā)現(xiàn),好像對于我們工控項目來說,能參考的地方不多,因為,他們用到的變量跟我們相比,數(shù)量根本不在一個數(shù)量級!
工控項目,用到的硬件點(diǎn)數(shù)幾百點(diǎn)是很平常的,稍微規(guī)模大一點(diǎn),就是幾千點(diǎn)甚至上萬點(diǎn)。而除了硬點(diǎn)之外,還要有一些通訊和上位控制的虛點(diǎn),加起來數(shù)量就更多了。這些點(diǎn),全都相當(dāng)于高級編程語言里的全局變量。任何一個高級語言編出來的程序,功能可能比我們做到的復(fù)雜,但全局變量,絕不可能用到這么多。除非那是個新手,不懂得要模塊化編程。
所以,最終工控項目的變量的命名規(guī)范,我們能參考到的可借鑒的經(jīng)驗只有,用英文!
即便英語不夠好,也得堅持用英文。因為,中文實在不方便作為變量名字,沒法簡略,太長,還不容易輸入。其次也不可以使用漢語拼音。完整的拼音也是太長,而且同音詞太多引發(fā)歧義多,不能精確描述。而簡化了使用拼音首字母的連拼,寫出來后簡直是天書,除了作者自己,別人根本不可能看懂說的是什么。而且即便作者自己,時間稍微一放,回過頭來就不明白啥意思了。
其實一個規(guī)范的工程項目,所有設(shè)備,都應(yīng)該有位號,所以在變量命名的時候,最簡單的方式是使用位號來命名,而同一位號之下的各種輸入輸出,手動、自動、啟動、停止、打開、關(guān)閉、運(yùn)行反饋、故障、開度、頻率等等,就可以統(tǒng)一規(guī)范的使用英文了,畢竟這點(diǎn)英文單詞數(shù)量還不算多。
而具體到位號的命名以及鏈接了后面的功能點(diǎn)的命名,就不可避免要出現(xiàn)鏈接符號,綜合S7的符號表的命名規(guī)則和WINCC的變量的命名規(guī)則,很多符號是禁止使用或者使用中有風(fēng)險的。比如:/\<>!+,;等基本都不能使用。
作為分隔符來說,點(diǎn)(.)是最方便的。但可惜的是,WINCC已經(jīng)缺省當(dāng)作是結(jié)構(gòu)變量的分隔符了,如果如鏈接S7-200,S7-1200的變量,不能使用結(jié)構(gòu)變量,直接通過OPC傳輸?shù)淖兞浚瑒t無法再使用點(diǎn)(.)
減號(-),現(xiàn)實的文檔中經(jīng)常用,但我說有風(fēng)險的恰恰就是它。在它上面我曾經(jīng)吃過虧,一個晚上幾個小時,翻來覆去倒騰好幾次變量,都是因為這個減號。這里,我只需要提兩件事大家可以測試一下:
你在單獨(dú)起變量名字的時候,不管在S7中還是WINCC中,都是合法的可以使用的,但如果使用WINCC7.2的變量表復(fù)制粘貼功能,你從WINCC復(fù)制到EXCEL還是可以的,但倒過來復(fù)制的時候,所有變量名里面的減號都給變成了下劃線(_)。
還有是,如果是模擬量需要進(jìn)行變量歸檔,如果又使用了壓縮歸檔,那么在壓縮以后,不知道啥時候變量名也給變成了下劃線(_)!
是的。原來最好用的是下劃線。其實也只有下劃線最好用,所以所有人在命名的時候本來也都喜歡用它,最終一個完整的位號加功能鏈接起來后的變量就會到泛濫的程度,這就就又出現(xiàn)問題了。比如:
LS_DT_8_LEAK_F
LS_DT_9_LEAK_F
LS_DT_12_LEAK_F
LS_DT_13_LEAK_F
這些變量名,在WINCC中使用是沒有問題的,但如果我要用到變量前綴功能呢?如果WINCC程序處理中需要通過變量的分隔符來確定位號和功能,這么多下劃線可就亂套了。
在去年年底的一個項目中,我曾經(jīng)非常痛苦的每天晚上花4-5個小時來處理幾千個變量的變量表,配合方每發(fā)來一次更新的變量表,我就要處理一次,以達(dá)到程序可用的規(guī)范。更換掉不可以使用的字符,更換掉不合適的使用了下劃線的變量。
直到最后,項目已經(jīng)完工了,突然想到了一個更容易的解決方案,既然濫用下劃線,那索性更濫用好了,分隔符的地方,使用連續(xù)兩個下劃線(_ _)可好?
比如上面的變量名就變成:
LS_DT_8__LEAK_F
LS_DT_9__LEAK_F
LS_DT_12__LEAK_F
LS_DT_13__LEAK_F
我只要和配合方在遞交變量點(diǎn)表的時候提前約定這樣一個規(guī)范不就OK了么!
然后轉(zhuǎn)過年來,又一個WINCC報表項目,我查了下項目中的變量的命名方式,直接提出了這樣的要求,所以變量名字就變成了:
FT-2128__L
FT-2128__S
FT-2128__D
FT-2128__M
FT-BCEG01__L
FT-BCEG01__S
FT-BCEG01__D
FT-BCEG01__M
當(dāng)然朋友在做的時候是一頭霧水,不明白為啥要這樣,現(xiàn)在看到這里,應(yīng)該也明白了吧!
至于變量名中還有的減號,因為變量已經(jīng)建立,已經(jīng)既成事實,就只好將錯就錯了。
本文標(biāo)簽:S7h和WINCC變量命名規(guī)范
* 由于無法獲得聯(lián)系方式等原因,本網(wǎng)使用的文字及圖片的作品報酬未能及時支付,在此深表歉意,請《S7h和WINCC變量命名規(guī)范》相關(guān)權(quán)利人與機(jī)電之家網(wǎng)取得聯(lián)系。
關(guān)于“S7h和WINCC變量命名規(guī)范”的更多資訊










