我們在程式寫作的時候的時候,偶爾會遇到需要處理樣板的情況,例如:
Hi! XXX您好,您X月的贍養管理費未繳,請盡速繳納...
Hi! XXX您好,您X月的贍養管理費未繳,請盡速繳納...
由於某個衝動的承諾,最近再次接觸到 VBA (Visual Basic for Application) 程式碼,對 Excel 工作表進行客製化。雖然需求挺簡單的,程式碼也不多,可是寫 VBA 這件事對我來說,並不是像寫 C#/.NET 一樣容易遇上,再加上 VBA 中很重要的 Office Object Model 還挺複雜的,小弟實在沒辦法塞太多 Office Object Model 的東東在腦子裡,這時候要靠文件嗎?可能一個小小的需求就會查到我天昏地暗,寫不下去…
所以在這邊分享一個小方法,能讓你快速的使用 VBA 完成你的工作,懂得一些 VB 的邏輯與控制結構語法即可,關於 Office Object Model 就借助工具幫忙。
Expression tree 自此之後開始快速欺凌擴展 .NET 程式設計師的視野,應用之廣泛像是 ASP.NET MVC 2 中開始提供在強型別 View 中應用 lambda 運算式 (lambda 也是一種 expression tree) 來作為舊語法無法支援 IntelliSense、編譯時期檢查和 refactoring support 的取代品(強烈建議使用),可參考 ScottGu’s Blog - ASP.NET MVC 2: Strongly Typed Html Helpers 這篇文章,相信有經驗的你很快的可以分辨出孰優孰劣。
我自己則是應用 expression tree 在推論引擎的實作上,先提一下推論引擎。前一段時間為了實作規則庫推論引擎(專家系統的一種分支),花了一段時間研究,這種系統的特性是:一個規則庫(Rule Base 或 Knowledge Base)、工作記憶體(Working Memory)與推論引擎(Inference Engine),架構大致如下:
// 以 function 為建構子 function Person(firstName, lastName) { this.firstName = firstName; this.lastName = lastName; } //然後活化類別 var p = new Person("Dino", "Wang");
// 附加一個匿名函式到 p 實體 p.fullName = function () { return this.firstName + " " + this.lastName; }
... true ...
...
// JavaScript var data = new Object(); data.name = "Dino"; data.sex = "Male";另一種 JavaScript 等價程式碼 (JSON 表示法)
// JavaScript var data = { name: "Dino", sex: "Male" };程式執行下來 data 含有 name、sex 這兩個屬性,並且值也被賦予了,我不必先為他產生類別定義,多麼簡單直覺!