零吓肋、開(kāi)始之前
為什么要寫(xiě)這篇文章?
至今我還總是能聽(tīng)到各種 BIM “落地難”的抱怨夭咬,然而我卻仍舊不明白什么是“落地難”链峭。
可能鋼結(jié)構(gòu) BIM 和其他 BIM 完全是兩個(gè)不同世界……也可能我一直做的是假 BIM :)
言歸正傳着绊,本文聊一聊自學(xué)編程的那些事兒。
本文的讀者對(duì)象是工作在一線的熟尉、編程零基礎(chǔ)的 BIMer归露。
因?yàn)樾¤D是自學(xué)編程,深知邁出第一步的艱難斤儿,所以小鐳打算將自己的學(xué)習(xí)心得分享給大家剧包,希望有助于大家自學(xué)編程。
小鐳也希望本文能起到拋磚引玉的作用往果,希望有更多的 BIMer 來(lái)分享自己的學(xué)習(xí)心得和經(jīng)驗(yàn)疆液。
本文不足之處還請(qǐng)各位 BIMer 批評(píng)指正。
BIMer 為什么要學(xué)習(xí)編程陕贮?
我們知道 BIM 中的 I 是信息堕油,是 BIM 的核心。
那么我們對(duì) IT,也就是信息技術(shù)了解多少呢掉缺?有人以為企業(yè)的 IT 崗位就是網(wǎng)管……
為了更好地實(shí)踐 BIM卜录、為了高效地生產(chǎn)和利用數(shù)據(jù),我們需要學(xué)習(xí)編程眶明。
為什么選擇自學(xué)艰毒?
與傳統(tǒng)的培訓(xùn)教學(xué)相比,小鐳更喜歡自學(xué)搜囱。主要是因?yàn)樽詫W(xué)可以自己掌控節(jié)奏丑瞧,也不用因?yàn)閰⒓优嘤?xùn)班而把大把的時(shí)間花在交通上,而且現(xiàn)在網(wǎng)絡(luò)上各種資源非常豐富蜀肘,很多還是免費(fèi)的绊汹,這極大地降低了學(xué)習(xí)成本。
基本上任何事情幌缝,培訓(xùn)教學(xué)只能讓人入門(mén)灸促,只有自學(xué)、自省才能讓人真正地突破自己涵卵。當(dāng)然浴栽,要保持學(xué)習(xí)的熱情和動(dòng)力,首先還得感興趣轿偎。
選擇什么編程語(yǔ)言典鸡?
因?yàn)?Office 軟件是職場(chǎng)標(biāo)配,VBA 是其自帶的編程語(yǔ)言坏晦,且具有上手快萝玷、功能強(qiáng)等優(yōu)勢(shì),所以小鐳推薦大家選擇 VBA 作為起步語(yǔ)言昆婿。
Excel + VBA 足以解決工作中遇到的大多數(shù)問(wèn)題球碉。對(duì)于企業(yè),Office 可能是性價(jià)比最高的生產(chǎn)力工具仓蛆,用好 Office 甚至可以極大地降低專(zhuān)業(yè) BIM 軟件的采購(gòu)成本睁冬。
作為 BIMer,我們學(xué)習(xí)編程的目的不是成為職業(yè)程序員或黑客看疙,而是要解決工作中遇到的問(wèn)題豆拨、要提高工作效率,所以我們學(xué)習(xí)編程要側(cè)重實(shí)用性能庆。
如果你對(duì)編程興趣濃厚施禾,那么你可以把學(xué)習(xí) VBA 作為一個(gè)開(kāi)始,這有助于你理解編程相關(guān)概念和思想搁胆,為以后學(xué)習(xí)其他語(yǔ)言打好基礎(chǔ)弥搞。
工具
一臺(tái)裝有微軟公司 Windows 操作系統(tǒng)和 Office Excel 軟件的計(jì)算機(jī)邮绿。
參考資料
小鐳強(qiáng)烈推薦這本書(shū),這里有關(guān)于 Excel VBA 的一切:
《Excel 2007 VBA參考大全》豆瓣鏈接
一拓巧、Hello World
Hello World 與 立即窗口
程序員寫(xiě)的第一行代碼通常都是讓計(jì)算機(jī)顯示“Hello World”(女生們也可能會(huì)喜歡用“Hello Kitty”)斯碌。
《The C Programme Language》的作者 Brian Kernighan 使用 “Hello World” 作為第一個(gè)演示程序。關(guān)于“Hello World”的更多內(nèi)容詳見(jiàn)維基百科肛度。
現(xiàn)在我們要使用 VBA 來(lái)寫(xiě)出我們的“Hello World”傻唾。
首選我們需要打開(kāi) VBA 編輯器,可以使用快捷鍵 Alt + F11 承耿。
2007版以后的 Excel 可以通過(guò) 【開(kāi)發(fā)工具】選項(xiàng)卡中的【Visual Basic】按鈕打開(kāi)編輯器冠骄,如果你看不到該選項(xiàng)卡,則需要在選項(xiàng)中進(jìn)行設(shè)置加袋。
然后在 VBA 編輯器中開(kāi)啟【立即窗口】凛辣,可以使用快捷鍵 Ctrl + G。
【立即窗口】顧名思義职烧,可以立即執(zhí)行你輸入的代碼并顯示結(jié)果扁誓。
接下來(lái)我們可以輸入如下代碼并按 Enter 鍵試試看:
msgbox "Hello World"
此時(shí)你應(yīng)該可以看到一個(gè)內(nèi)容為 Hello World 的彈出框:
太好了,代碼執(zhí)行正常蚀之。是不是很簡(jiǎn)單蝗敢?頓時(shí)覺(jué)得編程似乎并不是那么神秘和困難。
VBA 編輯器具有智能提示的功能足删,比如你鍵入 msg 并使用快捷鍵 Ctrl + J 后會(huì)發(fā)現(xiàn)有一個(gè)列表供你選擇:
此時(shí)你可以按 Tab 鍵或 空格 鍵來(lái)完成智能提示語(yǔ)句的輸入寿谴,并補(bǔ)全代碼:
MsgBox "Hello World"
你會(huì)發(fā)現(xiàn) msgbox
這個(gè)命令的正確寫(xiě)法是有大小寫(xiě)的 MsgBox
。
雖然 VBA本身并不是大小寫(xiě)敏感的失受,但是在命名中使用正確的大小寫(xiě)風(fēng)格是十分重要和必要的讶泰,且會(huì)提高代碼的可讀性。
宏
比起在立即窗口中執(zhí)行 Hello World 代碼拂到,我們更常見(jiàn)的與 VBA 親密接觸的場(chǎng)景是錄制宏痪署。
這個(gè)功能比較有趣,我們可以立即來(lái)用一下兄旬,在錄制宏的過(guò)程中惠桃,請(qǐng)注意 VBA 編輯器中的變化。
我們隨便做一些操作辖试,比如選中一個(gè)單元格,看看會(huì)發(fā)生什么事:
這個(gè)宏里面居然出現(xiàn)了一行代碼劈狐,太神奇了罐孝!這行代碼所執(zhí)行的操作,就是選中一個(gè)名為 B2 的單元格肥缔。我們可以先停止錄制宏莲兢,并嘗試在【立即窗口】中驗(yàn)證剛才得到的代碼。
先選中一個(gè)其他的單元格,比如 D1改艇,然后在【立即窗口】中執(zhí)行這行代碼收班,看看會(huì)發(fā)生什么變化:
Range("B2").Select
這時(shí)我們發(fā)現(xiàn) B2 單元格變成了當(dāng)前選中的單元格。
小結(jié)
本章介紹了 VBA 的開(kāi)發(fā)環(huán)境谒兄、宏的錄制以及立即窗口的使用摔桦。
Excel 給我們提供了一個(gè)編程游樂(lè)場(chǎng),我們可以在此盡情地玩耍了承疲。
由于本文的目的是希望幫助大家自學(xué)編程邻耕,所以有關(guān)軟件操作方面的內(nèi)容,大家可以查看幫助文檔燕鸽、搜索其他文章以及自行嘗試兄世。
下一章 寫(xiě)給 BIMer 的零基礎(chǔ)編程自學(xué)指南(二) 對(duì)象
Photo by Greg Rakozy on Unsplash