江恩十二條買賣法則之五
江恩十二條買賣法則之五:市場分段運動
股市按三到四段,或三至四浪運動。如果市場剛向上運行了第一段,永遠不要認為它已經到達了最終的頭部,因為如果這是一個真正的牛市,它會在到達頭部前至少運行三段,而且很可能是四段。
在熊市下跌市道中,當市場剛走完第一跌或第一段時,千萬不要認為市場已到達底部,因為在熊市過去以前,它會運行三段,甚至可能是四段。
這裡,將是我對我所學的知識做一簡要記載的地方,包括股票、攝影、程式設計。
這裡的資料,並不受限於一般部落格之以日為主的發佈流程。舊發佈內容將隨時可被更動修正,以維持資料之正確性。
KEVIN
江恩十二條買賣法則之五:市場分段運動
股市按三到四段,或三至四浪運動。如果市場剛向上運行了第一段,永遠不要認為它已經到達了最終的頭部,因為如果這是一個真正的牛市,它會在到達頭部前至少運行三段,而且很可能是四段。
在熊市下跌市道中,當市場剛走完第一跌或第一段時,千萬不要認為市場已到達底部,因為在熊市過去以前,它會運行三段,甚至可能是四段。
江恩十二條買賣法則之四:按三週上漲或下跌買賣。 當市場逆趨勢出現調整或反彈時,江恩認為在以下的時間必須留意市勢的發展:
江恩在對金融市場做了十分廣泛性的統計,他將市場反彈或調整的買賣歸納為兩點:
江恩十二條買賣法則之三:按百分比買賣。
只要這些下跌或反彈處於主要的趨勢之中,正如利用平均指數的百分比那樣,你可以利用個股的百分比判斷支撐阻力位和買賣點。
你可以使用:
這些百分比,其中最重要的阻力位是50%,其次是100%,也可再加入100%的倍數比例(其取決於從最高價或最低價開始的價格和時間週期),第三是25%,第四是12.5%,第五是6.25%(這儘在平均指數或個股在非常高的價位時使用),第六是33.33%和66.66%。
圖2 調整浪的支持水平
江恩十二條買賣法則之二:在單底、雙底和三重底買入(在單頂、雙頂和三重頂賣出)。
雙頭和雙底的意義:
江恩十二條買賣法則之一:研判趨勢。 圖1 恒生指數三天圖 三天圖的意思是,將市場的波動,以三天的活動為記錄的基礎。這裡的三天是自然日,包括週六和週日,而並非交易日。三天圖表的規則是,當三天的最低水平下破,則表示市場會向下;當三天的最高水平上破,則表示市場會出現新高。 繪圖方法上,可按照以下步驟: 除了三天圖外,江恩還建議使用一種名為平均指數九點轉向圖(九點平均波動圖)分析市勢。 圖2 恒生指數九點圖, 每單位等於10點 江恩所應用的,是在1912至1949年的道瓊工業平均指數之上,江恩的統計如下: 因此,市場上落9點至21點,是一個重要的市場轉折的指標。 平均指數九點轉向圖(九點平均波動圖)的規則是: 對於上升的市道中,規則亦一樣。 在制作圖表時,若市況上升超過9點,圖表線可作上升,圖表線跟隨每日高點上移,直至市場出現9點的下跌,圖表線才跟隨下移至當日低點。 三天圖及九點圖與點數圖十分類似,都是以跟隨市勢的方式繪製。不過,江恩上述圖表有幾點需要注意:
江恩認為,對於所有市場,決定其趨勢是最重要的一點,至於如何決定其趨勢,學問便在裡面。
對於股票而言,其平均綜合指數最為重要,以決定大市的趨勢。此外,分類指數對於市場的趨勢亦有相當啟示性。所選擇的股票,應以根據大市的趨勢者為主。若將上面規則應用在外匯市場上,則"美元指數"將可反映外匯走勢的趨向。
在應用上面規則時,他建議分析者使用一種特殊的圖表方式,對於大市指數來說,應以三天圖及平均指數九點轉向圖(九點平均波動圖)為主。
若市場下跌兩天後第三天再創新高,則圖表上的線應垂直上移至當天的高點。
若市場繼續下跌,則可將圖表上的線垂直下移至當天的低點。
在實際應用九點圖時,分析者必先了解所分析的市場,例如在外匯市場中的傾向的平均上落幅度,所取的幅度應以超過50%的出現機會為佳。
三為時間的界限,九為空間的界限。在三的限制中,讓趨勢自然的增長;在九的空間中,讓時間盡情回蕩。
三天的三是實數,九點中的九是虛數。
江恩十二條買賣法則:
江恩二十一條買賣守則:(以下有二十五條,是另外從別的文獻中補充進來的)
江恩理論是以研究測市為主的,江恩通過數學、幾何學、宗教、天文學的綜合運用,建立起自己獨特的分析方法和測市理論。由於他的分析方法具有非常高的準確性,有時達到令人不可思議的程度,因此很多江恩理論的研究者非常注重江恩的測市系統。但在測市系統之外,江恩還建立了一整套操作系統,當測市系統發生失誤時,操作系統將及時地對其進行補救。江恩理論之所以可以達到非常高的準確性,就是將測市系統和操作系統一同使用,相得益彰。 江恩在書中的建議是停損單設在買入價之下3~5%,考慮到市場波動幅度不同,或許可以放寬停損單的範圍,例如5~10%。 江恩理論的測市系統部份很多地方抽象難懂,不易理解,但江恩的操作系統和買賣規則卻清楚明確,非常容易理解。江恩的操作系統是以跟隨市場買賣為主,這與他的預測系統完全不同,江恩非常清楚地將買賣操作系統與市場預測系統分開,使他能在一個動盪充滿危機的年代從事投機事業而立於不敗之地。 江恩理論的實質就是在看似無序的市場中建立了嚴格的交易秩序,他建立了江恩時間法則、江恩價格法則、江恩線等。它可以用來發現何時價格會發生回調和將回調到什麼價位。 江恩線的數學表達有兩個基本要素,這兩個基本要素是價格和時間。江恩通過江恩圓形、江恩螺旋正方形、江恩六邊形、江恩輪中輪等圖形將價格與時間完美的融合起來。在江恩的理論中,『七』是一個非常重要的數字,江恩在劃分市場周期循環時,經常使用『七』或『七的倍數』,江恩認為七融合了自然、天文與宗教的理念。 江恩線是江恩理論與投資方法的重要概念,江恩在X軸上建立時間,在Y軸上建立價格,江恩線符號由『TXP』表示。江恩線的基本比率為1:1,即一個單位時間對應一個價格單位,此時的江恩線為45度。通過市場的分析,江恩還分別以3和8為單位進行劃分,如1/3和1/8等,這些江恩線構成了市場回調或上升的支撐位和阻力位。 通過江恩理論,我們可以比較準確的預測市場價格的走勢與波動,成為股市的贏家。當然,江恩理論也不是十全十美的,不能指望它使你一夜暴富,但是經過努力,在實踐中體會江恩理論的真締,他一定會使你受益匪淺。 記住永遠不要背離趨勢。在你決定市場趨勢時,隨其而動。遵守準則以決定趨勢,不要以猜測和希望來做交易。
江恩在1949年出版了他最後一本重要著作《在華爾街45年》,此時江恩已是72歲高齡,他坦誠的披露了縱橫市場數十年的取勝之道。其中江恩十二條買賣法則是江恩操作系統的重要組成成份,江恩在操作中還制定了二十一條買賣守則,江恩嚴格地按照十二條買賣法則和二十一條買賣守則進行操作。
江恩認為,進行交易必須根據一套既定的交易的規刖去操作,而不能隨意地買賣,盲目地猜測市場的發展情況。隨著時間的轉變,市場的條件也會跟隨轉變,投資者必須學會跟隨市場的轉變而轉變,而不能認死理。
江恩告戒投資者:在你投資之前請先細心研究市場,因為你可能會做出與市場完全相反的錯誤的買賣決定,同時你必須學會如何去處理這些錯誤。一個成功的投資者並不是不犯錯誤,因為在證券市場中面對千變萬化、捉摸不定的市場,任何一個人都可能犯錯誤,甚至是嚴重的錯誤。但成敗的關鍵是成功者懂得如何去處理錯誤,不使其繼續擴大;而失敗者因猶豫不決、優柔寡斷任錯誤發展,並造成更大的損失。
江恩曾出版過一些股票書籍,但是卻沒有一本比《華爾街45年》更能真正透露江恩成功的秘密。在這本書中所看到最多的字眼並非什麼江恩角度線、什麼時間周期或是輪中輪等,而是『停損單』三個字。單單在第二章,『停損單』便已經出現了8次之多。每一次出現,江恩都指出其重要性。
江恩說,大多數人在股市中輸錢主要有三個原因:註:
止蝕單又稱停止委託單(Stop Order),它是指只有當市價達到某一指定價格,委託單才可執行,此時它變為市價委託單(如果下的是停止委託單)或限價委託單(如果下的是限價停止委託單(Stop Limit Order))。買入停止委託單(相對空頭倉位或空倉)是指,只有當市價漲至指定價格時,委託單才可執行(亦即以指定價格或指定價格以上成交);賣出停止委託單(相對多頭倉位或多倉)是指,只有當市價跌至指定價格時,委託單才可執行(亦即以指定價格或指定價格以下成交)。在投資者不能經常性的觀察市場時,停止委託單尤其有用,市場變動引發的交易能使投資者保存利潤,或限制損失。停止委託單有兩種風險,其一,證券價格有時會突然發生變動(這一變動方向可能是暫時性的),從而導致證券過早成交;其二,指定價格一旦到達,停止委託單就變成了市價委託單,其執行價存在不確定性。
威廉‧江恩 (Willian Delbert Gann) --- 二十世紀最著名的投資家之一。
威廉‧江恩在股票和期貨市場上的驕人成績至今無人可比,他所創造的把時間與價格完美的結合起來的理論,至今仍為投資界人士所津津樂道、倍加推崇。
江恩於1878年6月6日(或說6月15日)出生於美國德克薩斯州的路芙根市(Lufkin Texas),父母是愛爾蘭裔移民。少年時代的江恩在火車上賣報紙和送電報,還販賣明信片、食品、小飾物等。
1902年,江恩在24歲時,第一次入市買賣綿花期貨。
1906年,江恩到俄克拉荷馬當經紀人,既為自己炒,亦管理客戶。
在1908年,江恩30歲時,他移居紐約,成立了自己的經紀業務。同年8月8日,發展了他最重要的市場趨勢推測方法,名為『控制時間因素』。經過多次準確預測後,江恩聲名大噪。
最為人矚目的是1909年10月美國"The Ticketr and Investment Digest(股票行情與投資文摘)"雜誌編輯Richard . Wyckoff的一次實地訪問。在雜誌人員的監察下,江恩在十月份的二十五個市場交易日中共進行286次買賣,結果264獲利,22次損失,獲利率竟達92.3%。 而資本額則增加了十倍,平均交易時間間隔是20分鐘。
在投資生涯中,成功率高達80%~90%,他用小錢賺取了巨大的財富,在其五十三年的投資生涯中共從市場上取得過三億五千萬美元的純利。
據江恩的一位朋友基利的回述:『1909年夏季,江恩預測9月小麥期權將會見1.20美元。可是,到9月30日芝加哥時間十二時,該期權仍然在1.08美元之下徘徊,江恩的預測眼看落空。江恩說:'如果今日收市時不見1.20美元,將表示我整套分析方法都有錯誤。不管現在是什麼會,小麥一定要見1.20美元。' 結果,在收市前一小時,小麥衝上1.20美元,震動整個市場,該合約不偏不倚,正好在1.20美元收市。』
江恩的事業高峰期,他共聘用二十五人,為他制作各種分析圖表及進行各類市場走勢研究,並成立兩間走勢研究公司:江恩科學服務公司及江恩研究公司,出版多種投資通訊。在他每年出版的全年走勢預測中,他清楚的繪製在什麼時間見什麼價位的預測走勢圖,精準性甚高。
江恩相信股票、期貨市場裡也存在著宇宙中的自然規則,市場的價格運行趨勢不是雜亂的,而是可通過數學方法預測的。江恩的數學方程並不複雜,實質就是價格運動必然遵守支撐線及壓力線,也就是---江恩線。
相機買回家,除了測試所有部件是否齊全及正常外,最重要的一件事,就是充電。
富士F100fd的電池,使用的是與F50fd相同規格的NP-50可充式鋰電池(3.7V,1000mAh),而使用的充電器型號為BC-50。
網路上有人說:『充電器直接內建旋出式插頭,非常適合旅行』,不知是不是因為我買的是水貨,我的BC-50充電器上並沒有內建旋出式插頭,只有電源線接孔。不過,網路上的那個訊息,他所拍出的充電器照片,也沒有拍出旋出式插頭的模樣,所以,沒有照片沒真象,真實情況是怎樣就不得而知了。
據店家老闆告知,充電池第一次充電時,要充6~8個小時,而我則給它充7個小時(呵呵,取中間值)。之後,每次再充時,只要看充電器上的燈號是否由紅燈轉為綠燈就好了。大約是將近兩個鐘頭吧,我都是充兩個鐘頭就拔起來了(說明書上寫大約是2.3小時)。原則上,充飽電後,好的充電器會對充電池做保護,不會令其過充而造成傷害,但,這個BC-50充電器沒有看到這樣的訊息,所以我也不敢隨意嚐試,只等自己可掌控的時間時,才進行充電動作。
底下,是說明書上對充電指示燈的狀態說明:充電指示燈:關閉 -> 未裝入電池
亮綠燈 -> 電池充電完成 -> 從電池充電器取出電池
亮紅燈 -> 正在充電
紅燈閃爍 -> 充電時電池出現故障 -> 拔掉電池充電器插頭,並從電池充電器中取出電池
注意事項:不使用時,請將電源充電器從電源插座中拔出。
低溫時充電,時間會延長。
即使閒置不用,NP-50電池也會逐漸放電,請在拍照前(之前一兩天)對NP-50進行充電。
NP-50所提供的只有1000mAh,雖然比另一款NP-40的850mAh多了些,但,始終覺得還不夠。我問店家老闆有沒有較大容量的電池可用,老闆說沒有。不過,老闆說,F100fd置放NP-50充電池的插槽,他感覺電池放進去時空間還鬆鬆的,他主觀性的認為將來可能會有更大容量的電池會出,他會上日本網站注意,如果有,客戶若需要,他會想辦法進貨。
原則上,NP-50充飽電後,按照官方說法,可以拍照230張,我沒有實測,所以不是很清楚。我有另外多買一顆副廠電池,在大部份時間裡都還夠用,但是,如果出野外時間太久又使用量過大時,應該會不夠用,到時,還是得再多買一兩顆備用才行。
說明書上有提到,如果您要使用交流電源為相機供電(它的意思是指不透過NP-50充電池,而是直接由電源插座連接至相機),需要使用另售的AC電源適配器(AC-5VX)和DC連接器(CP-50),此二者必須串連使用。(應該沒這必要吧,這樣反而大費周章,只不過,若拍攝位置不需遠離電源,那還真的可以讓電源源源不斷,除非停電,否則永遠不怕沒電)
富士小DC史上夜拍能力最強的機種F31fd,其所使用的充電池是NP-95,為3.6V、1800mAh,其電池續航力,顯然確實比NP-50大上許多。F40fd則使用NP-70,為3.7V、1500mAh,也比NP-50之續航力好。
PChome Online裡有賣這些電池,不懂為什麼富士要把電池搞得這麼複雜,為什麼不能共用,是否是相機內電路上的需求所致,我就不知道了。
2008/4/25,終於買了一台Fujifium(富士)F100fd來玩。在這之前,因為原有的Ricoh R1被小孩弄丟了,而手中有一台DSLR(Nikon D70s)可用,在沒有看到滿意的DC機種前,就一直忍著了。 不過,從雜誌上看到另一台DC將來要上市,規格性能可能都會更好,倒是可以注意看看:Sony Cyber-Shot W170,一樣是28~140mm,其餘功能似乎不錯,要上網查。 當天,買之前先問過兩個地方,一是燦坤(現場看到現貨),為公司貨,售價13500(其餘細節未問);另一是博愛路某家知名攝影器材行(電話直接詢問),一樣是公司貨,全配(含4G記憶卡,原廠相機皮套),售價13500。結果我到NOVA找,最後買的是水貨,單機售價9500。跟公司貨的差別,應該主要是在維修、及附加完整配備、還有中文說明書。 我所買及花費如下: 以下是富士F100fd的規格說明: 買回來後,有個小插曲,給將來碰到同樣問題者一個經驗分享。 因為當場沒有先做大幅度的測試,回家開始使用相機時,碰到第一個問題是,記憶卡無法順利使用,可拍可寫但卻讀取不順,尤其是使用動畫模式時。 剛好,我手邊有Ricoh R1當時留下來的一個舊SD卡(256M),換上後,結果一切正常。 哇!這下問題大了,打電話詢問店家老闆後,說可能是創見這批記憶卡有良率問題而造成相容性影響。因為創見記憶卡是終身保固,老闆建議我到K-MALL的一樓有一家創見的専賣店去換新,結果,換了好幾片都還是一樣問題。 創見的服務小姐好心拿了一片未折封的全新記憶卡讓我回購買店家那裡去處理(換較低容量者),結果,我回NOVA店家那兒,老闆不信邪,還是拆開來試,問題還是一樣。 後來,他發現相機設定裡的『視訊系統』預設在『PAL』,調成『NTSC』後,所有問題就消失了。 將來,這個主題系列,我會以富士F100fd為工具,介紹它的介面操作及在拍攝時的各方面應用。
因個人習慣需求,看中F100fd的理由有幾項:單機:9500(附一顆原廠NP-50充電式鋰電池、一組原廠充電器及電源連接線、一條AV端子連接線、一條USB傳輸線、一本F50fd影印說明書)。
F50fd說明書,到目前還沒翻過,自己動手摸索就會用了。
一顆副廠電池:500。
一片創見SDHC卡(8G):1100。
一個小包包:200。
一片螢幕保護貼:200(含幫忙貼好)。
共花11500元。有效畫素: 1200 萬
最大靜態影像: 4000x3000 像素
最大動畫: 640x480 像素
感光元件形式: 1/1.6吋super CCD HR
光學變焦: 5 倍
焦距換算: 28-140 mm
最大光圈: F3.2
數位變焦: 8.2 倍
未壓縮格式: 無
鏡片規格: 群枚
一般對焦最近距離: 45 cm
微距對焦最近距離: 5 cm
白平衡種類: 自動 / 日光 / 陰天 / 鎢絲燈 / 螢光燈 / 自設
ISO感光度: 100-12800
最高快門速度: 1/1600 秒
最低快門速度: 1/4 秒(夜景模式最長可至8秒)
測光系統: TTL256分割測光/點測光
曝光補償: ±+ / - 2級
重複曝光: 無
視度調整: 有
內置閃燈: 有
閃燈有效距離: W:0.6-4.3m T:0.6-2.8m
自拍器: 2 / 10 秒
連拍速度: 1.7 張/秒
連拍最多: 3 張
外接閃燈: 不可
機背LCD: 2.7 吋
語言: 日語/英語
單獨錄音功能: 有
傳輸介面: USB2.0
記憶卡: SD / XD / 內置記憶體
尺寸: 97.7(寬)x58.9(高)x23.4(深)mm
重量: 170 克
電源: 充電式鋰電池(NP-50)
國民所得,可有三種計算方式:GDP、GNP、GNI(Gross National Income,少用)。
通常,當國民所得中的各要素在國際間流動的程度越高時,會採用GDP。台灣和美國都是採用GDP。
其內容包括:民間消費(台灣約佔六成GDP比重)、政府消費、固定投資(政府、公營事業、民間)、存貨變動、商品及勞務輸出入。
GDP升高,代表該國或該地區的經濟在成長中,整體人民的購買能力提高,景氣活絡,值得投資。
GDP降低,代表該國或該地區的經濟停滯不前,整體人民的購買能力降低,景氣不佳,資金可能外移。
每人國民所得(Income Per Capita),即某一期間按市價計算之國民所得,除以該段期間人口總數而得出的數值,又稱為『平均每人國民所得』。
資料來源:行政院主計處,每2、5、8、11月中旬發佈,觀察上一季。
主要資料細網址:http://www.dgbas.gov.tw/ct.asp?xItem=14616&CtNode=3566中的第一項: 國民所得統計常用資料,其內容為Excel檔,而其檔名沒有規律可尋,不知是否為固定檔名,得觀察數季才行。故,目前只得自行下載回來看或另行處理。
以下整理各種經濟指標之查閱來源處。
消費者物價指數(CPI):每月5日,主計處,觀察上個月。
躉售物價指數(WPI):每月5日,主計處,觀察上個月。
外匯存底(FR):每月6日,中央銀行,觀察上個月。
進出口統計概況(MEX):每月8日,財政部,觀察上個月。
全國賦稅收入概況(TAX):每月9日,財政部,觀察上個月。
工業生產指數(IND):每月21日,經濟部,觀察上個月。
外銷訂單:每月21日,經濟部,觀察上個月。
失業(JobLess):每月23日,主計處,觀察上兩個月。
薪資增幅(Salaries):每月23日,主計處,觀察上個月。
貨幣供給額(M1/M2):每月25日,中央銀行,觀察上個月。
景氣對策信號:每月27日,經建會,觀察上個月。
領先指標:每月27日,經建會,觀察未來三到六個月。
同時指標:每月27日,經建會,觀察上個月。
退票率:每月29日,中央銀行,觀察上個月。
經濟成長率(GR,GNP,GDP):2、5、8、11月中旬,主計處,觀察上一季。
房地產景氣燈號:每季,內政部建築研究所,觀察上一季。
經濟成長率:6月、12月,中研院經研所
經濟成長率:1、4、7、10月中旬,中華經濟研究所
景氣動向調查月報:每月25日,台灣經濟研究所
經濟成長率:2、5、8、11月中旬,台灣經濟研究所及台灣綜合研究院
消費者信心調查:每月,台灣綜合研究院
每年1、4、7、10月底,環球透視預測機構(Global Insight Inc.)
每年5、11月,經濟合作暨發展組織(OECD)
每年5、9月,國際貨幣基金(IMF)
每年10月左右,世界銀行(WB)
一、指定資料來源(From):這是LINQ查詢的第一步,From子句一定排在最前面。它可指定一個或多個範圍變數以及要查詢的集合。From element [ As type ] In collection [ _ ]
[, element2 [ As type2 ] In collection2 [, ... ] ]
其中,element及collection為必要項,type則為選擇項。
可以在查詢中指定多個From子句,也可以在單一From子句中將每個相關的範圍變數和集合以逗號隔開,藉以指定多個範圍變數和集合。這兩種寫法如下:' Multiple From clauses in a query.
也可以組成一個巢狀From子句,其中第二個子句中的集合是根據第一個子句中的範圍變數屬性:
Dim result = From var1 In collection1, var2 In collection2
' Equivalent syntax with a single From clause.
Dim result2 = From var1 In collection1 _
From var2 In collection2Dim allOrders = From cust In GetCustomerList() _
From ord In cust.Orders _
Select ord
二、篩選資料(Where):Where子句會用來執行篩選,而查詢接著只會傳回運算式為true的項目。可以使用邏輯運算子(如And、Or、AndAlso、OrElse、Is 和 IsNot)來合併Where子句中的篩選條件運算式。From element [ As type ] In collection [ _ ]
[, element2 [ As type2 ] In collection2 [, ... ] ]
Where condition
可以在 Where 子句中呼叫函式,以對集合中目前項目的值執行計算或作業。在 Where 子句中呼叫函式會使查詢在進行定義時就立即執行,而不是等到進行存取時才執行。
三、排序資料(Order By): Order By子句會根據指定的一個或多個欄位來排序所傳回序列中的項目。From element [ As type ] In collection [ _ ]
[, element2 [ As type2 ] In collection2 [, ... ] ]
Where condition
Order By orderExp1 [ Ascending Descending ] [, orderExp2 [...] ]
Order By 子句只能根據目前範圍 (Scope) 的範圍 (Range) 變數排序結果。例如,Select 子句在查詢運算式中引入新的範圍 (Scope),並用新的反覆運算變數代表該範圍 (Scope)。在查詢中 Select 子句之前定義的範圍 (Range) 變數在 Select 子句之後就無法使用。因此,如果您要依 Select 子句中無法使用的欄位排序結果,就必須將 Order By 子句放在 Select 子句前面。您必須這麼做的其中一個範例就是依不在傳回結果中的欄位來排序查詢時。
為必要項。目前查詢結果的一個或多個欄位,用以識別如何排序傳回的值。欄位名稱必須以逗號(,)分隔。可以使用Ascending或Descending關鍵字,將每個欄位識別為以遞增或遞減順序排序。如果未指定Ascending或Descending關鍵字,預設排序次序是遞增排序。排序次序欄位優先順序是由左至右。
四、選取資料(Select):Select子句會指定所傳回項目的格式和內容。From element [ As type ] In collection [ _ ]
[, element2 [ As type2 ] In collection2 [, ... ] ]
Where condition
Order By orderExp1 [ Ascending Descending ] [, orderExp2 [...] ]
Select [ var1 = ] fieldName1 [, [ var2 = ] fieldName2 [...] ]
查詢不一定需要Select子句。如果未指定Select子句,查詢會依據目前範圍所識別之範圍變數的所有成員傳回型別。
Select子句可以參考目前範圍中的任何變數。這包含From子句中識別的範圍變數,也包含由Aggregate、Let、Group By或Group Join子句之別名所建立的新變數,或由查詢運算式中先前Select子句所決定的變數。
若要擷取包含完整 Customer 物件的集合,請選取範圍變數本身:Dim londonCusts2 = From cust In customers _
Where cust.City = "London" _
Order By cust.Name Ascending _
Select cust
如果 Customer 執行個體 (Instance) 是擁有多個欄位的大型物件,而您只要擷取名稱,則可以選取 cust.Name (如下列範例所示)。區域型別推斷會知道要將結果的型別從 Customer 物件的集合變更為字串的集合。Dim londonCusts3 = From cust In customers _
Where cust.City = "London" _
Order By cust.Name Ascending _
Select cust.Name
若要選取資料來源中的多個欄位,您有兩個選擇:
因為在下列範例中傳回的項目是匿名型別執行個體,所以無法在程式碼的別處依名稱來參考該型別。編譯器指定的型別名稱會包含一般 Visual Basic 程式碼中無效的字元。在下列範例中,由 londonCusts4 內的查詢所傳回之集合中的項目會是匿名型別執行個體。Dim londonCusts4 = From cust In customers _
Where cust.City = "London" _
Order By cust.Name Ascending _
Select Name = cust.Name, Phone = cust.Phone
For Each londonCust In londonCusts4
Console.WriteLine(londonCust.Name & " " & londonCust.Phone)
NextPublic Class NamePhone
Public Name As String
Public Phone As String
' Additional class elements
End Class
Dim londonCusts5 = From cust In customers _
Where cust.City = "London" _
Order By cust.Name Ascending _
Select New NamePhone With {.Name = cust.Name, _
.Phone = cust.Phone}
Select子句也可以包含靜態值。例如,下列程式碼範例會顯示查詢運算式,其中 Select 子句會將查詢結果定義為匿名型別並具有四個成員:ProductName、Price、Discount 及 DiscountedPrice。ProductName 和 Price 成員值是取自 From 子句中定義的產品範圍變數。DiscountedPrice 成員值是在 Let 子句中計算。Discount 成員是靜態值。' 10% discount
Dim discount_10 = 0.1
Dim priceList = _
From product In products _
Let DiscountedPrice = product.UnitPrice * (1 - discount_10) _
Select product.ProductName, Price = product.UnitPrice, _
Discount = discount_10, DiscountedPrice
Select 子句會引入新的範圍變數集供後續查詢子句使用,範圍中不再有先前的範圍變數。查詢運算式中最後一個 Select 子句會決定查詢的傳回值。例如,下列查詢會傳回總值超過 500 的每份客戶訂單的公司名稱和訂單 ID。第一個 Select 子句識別 Where 子句和第二個 Select 子句的範圍變數。第二個 Select 子句識別查詢傳回的值,做為新匿名型別。Dim customerList = From cust In customers, ord In cust.Orders _
Select Name = cust.CompanyName, _
Total = ord.Total, ord.OrderID _
Where Total > 500 _
Select Name, OrderID
如果 Select 子句識別單一項目以傳回,則查詢運算式會傳回該單一項目之型別的集合。如果 Select 子句識別多個項目以傳回,則查詢運算式會依據選取的項目傳回新匿名型別的集合。例如,下列兩個查詢會依據 Select 子句傳回兩個不同型別的集合。第一個查詢會以字串傳回公司名稱集合。第二個查詢會傳回以公司名稱和地址資訊填入 (Populate) 之 Customer 物件的集合。Dim customerNames = From cust In customers _
Select cust.CompanyName
Dim customerInfo As IEnumerable(Of Customer) = _
From cust In customers _
Select New Customer With {.CompanyName = cust.CompanyName, _
.Address = cust.Address, _
.City = cust.City, _
.Region = cust.Region, _
.Country = cust.Country}
五、聯結資料(Join 和 Group Join):
Join 關鍵字相當於 SQL 中的 INNER JOIN。它會根據兩個集合中項目的相符索引鍵值來合併兩個集合。Join element In collection _
[ joinClause _ ]
[ groupJoinClause ... _ ]
On key1 Equals key2 [ And key3 Equals key4 [... ]
可以執行隱含聯結 (Implicit Join) 來合併集合,而不需要使用 Join 子句。其做法是在 From 子句中加入多個 In 子句,然後指定 Where 子句以識別要使用的聯結索引鍵。
聯結條件中使用的索引鍵,可以是包含集合中之多個項目的運算式。不過,每個索引鍵運算式只能包含其針對之集合中的項目。Dim customerIDs() = {"ALFKI", "VICTE", "BLAUS", "TRAIH"}
Dim customerList = From cust In customers, custID In customerIDs _
Where cust.CustomerID = custID _
Select cust.CompanyName
下列程式碼範例會使用 Join 子句聯結兩個集合。Imports System.Diagnostics
Public Class JoinSample
Public Sub ListProcesses()
Dim processDescriptions As New List(Of ProcessDescription)
processDescriptions.Add(New ProcessDescription _
With {.ProcessName = "explorer", _
.Description = "Windows Explorer"})
processDescriptions.Add(New ProcessDescription _
With {.ProcessName = "winlogon", _
.Description = "Windows Logon"})
processDescriptions.Add(New ProcessDescription _
With {.ProcessName = "cmd", _
.Description = "Command Window"})
processDescriptions.Add(New ProcessDescription _
With {.ProcessName = "iexplore", _
.Description = "Internet Explorer"})
Dim processes = From proc In Process.GetProcesses _
Join desc In processDescriptions _
On proc.ProcessName Equals desc.ProcessName _
Select proc.ProcessName, proc.Id, desc.Description
For Each proc In processes
Console.WriteLine("{0} ({1}), {2}", _
proc.ProcessName, proc.Id, proc.Description)
Next
End Sub
End Class
Public Class ProcessDescription
Public ProcessName As String
Public Description As String
End Class
下列程式碼範例會使用 Join 子句並搭配兩個索引鍵資料行聯結兩個集合。Imports System.Diagnostics
Public Class JoinSample2
Public Sub ListProcesses()
Dim processDescriptions As New List(Of ProcessDescription2)
' 8 = Normal priority, 13 = High priority
processDescriptions.Add(New ProcessDescription2 _
With {.ProcessName = "explorer", _
.Description = "Windows Explorer", _
.Priority = 8})
processDescriptions.Add(New ProcessDescription2 _
With {.ProcessName = "winlogon", _
.Description = "Windows Logon", _
.Priority = 13})
processDescriptions.Add(New ProcessDescription2 _
With {.ProcessName = "cmd", _
.Description = "Command Window", _
.Priority = 8})
processDescriptions.Add(New ProcessDescription2 _
With {.ProcessName = "iexplore", _
.Description = "Internet Explorer", _
.Priority = 8})
Dim processes = From proc In Process.GetProcesses _
Join desc In processDescriptions _
On proc.ProcessName Equals desc.ProcessName _
And proc.BasePriority Equals desc.Priority _
Select proc.ProcessName, proc.Id, desc.Description, _
desc.Priority
For Each proc In processes
Console.WriteLine("{0} ({1}), {2}, Priority = {3}", _
proc.ProcessName, _
proc.Id, _
proc.Description, _
proc.Priority)
Next
End Sub
End Class
Public Class ProcessDescription2
Public ProcessName As String
Public Description As String
Public Priority As Integer
End Class
Group Join 會將多個集合合併成單一階層式集合,這與 SQL 中的 LEFT JOIN 類似。Group Join element [As type] In collection _
On key1 Equals key2 [ And key3 Equals key4 [... ] ] _
Into expressionList
Group Join 子句是根據要聯結之集合中的相符索引鍵值來合併兩個集合。所產生的集合包含一個成員,這個成員參考第二個集合中所有與第一個集合中的索引鍵值相符合之項目的集合。您也可以指定彙總函式,以套用至從第二個集合群組得來的項目。
聯結條件中使用的索引鍵,可以是包含集合中之多個項目的運算式。不過,每個索引鍵運算式只能包含其針對之集合中的項目。
Group Join 作業所產生的集合中,可以包含 From 子句所識別集合中以及 Group Join 子句的Into 子句所識別運算式中的任意值組合。
Group Join 作業會傳回 Group Join 運算子左邊所識別之集合的所有結果。即使要聯結的集合中沒有符合項目,也是一樣。這和 SQL 中的 LEFT OUTER JOIN 相似。
您可以使用 Join 子句,將集合合併成單一集合。這相當於 SQL 中的 INNER JOIN。
下列程式碼範例會使用 Group Join 子句聯結兩個集合:Dim customerList = From cust In customers _
Group Join ord In orders On _
cust.CustomerID Equals ord.CustomerID _
Into CustomerOrders = Group, _
OrderTotal = Sum(ord.Total) _
Select cust.CompanyName, cust.CustomerID, _
CustomerOrders, OrderTotal
For Each customer In customerList
Console.WriteLine(customer.CompanyName & _
" (" & customer.OrderTotal & ")")
For Each order In customer.CustomerOrders
Console.WriteLine(vbTab & order.OrderID & ": " & order.Total)
Next
Next
六、分組資料(Group By):加入 Group By 子句,根據項目的一個或多個欄位來分組查詢結果中的項目。也可以用來將彙總函式 (Aggregate Function) 套用至每個群組。群組作業是根據一個或多個索引鍵。Group [ listField1 [, listField2 [...] ] By keyExp1 [, keyExp2 [...] ]
Into aggregateList
您可以使用 Group By 子句,將查詢結果分成數個群組。群組作業是根據索引鍵,或由多個索引鍵所組成的複合索引鍵。與相符索引鍵值關聯的項目,就會加入相同的群組。Into Group
使用 Into 子句的 aggregateList 參數和 Group 關鍵字,可以識別用於參考群組的成員名稱。您也可以將彙總函式加入 Into 子句以計算群組項目的值。Dim studentsByYear = From student In students _
Select student _
Group By year = student.Year _
Into Classes = Group
For Each yearGroup In studentsByYear
Console.WriteLine(vbCrLf & "Year: " & yearGroup.year)
For Each student In yearGroup.Classes
Console.WriteLine(" " & student.Last & ", " & student.First)
Next
Next
七、彙總函式(Aggregate):將一個或多個彙總函式 (Aggregate Function) 套用至集合。Aggregate element [As type] In collection _
[, element2 [As type2] In collection2, [...]]
[ clause ]
Into expressionList
Aggregate 子句可以用來將彙總函式包含在查詢中。彙總函式會對值集執行檢查及計算,並傳回單一值。您可以使用查詢結果型別的成員來存取計算值。您可以使用的標準彙總函式為 All, Any、Average、Count、LongCount、Max、Min 及 Sum 函式。
彙總函式的結果包含在查詢結果中,做為查詢結果型別的欄位。您可以套用彙總函式結果的別名,以指定會保留彙總值之查詢結果型別之成員名稱。如果未提供別名,則會使用彙總函式的名稱。
Aggregate 子句可以用來開始查詢,也可以包含在查詢中做為額外子句。如果 Aggregate 子句用來開始查詢,則結果會是單一值,此值是 Into 子句中指定之彙總函式的結果。如果在 Into 子句中指定一個以上的彙總函式,查詢會傳回具有個別屬性的單一型別,以參考 Into 子句中每個彙總函式的結果。如果將 Aggregate 子句做為查詢中的額外子句,則查詢集合中傳回的型別會有個別的屬性,用以參考 Into 子句中每個彙總函式的結果。
All:如果集合中的所有項目都滿足指定的條件則傳回 true,否則會傳回 false。Dim customerList1 = Aggregate order In orders _
Into AllOrdersOver100 = All(order.Total >= 100)
Any:如果集合中的任何項目滿足指定的條件則傳回 true,否則會傳回 false。Dim customerList2 = From cust In customers _
Aggregate order In cust.Orders _
Into AnyOrderOver500 = Any(order.Total >= 500)
Average:計算集合中所有項目的平均值,或計算針對集合中所有項目而提供的運算式。Dim customerOrderAverage = Aggregate order In orders _
Into Average(order.Total)
Count:計算集合中的項目數。您可以提供選擇性的 Boolean 運算式,只計算集合中滿足條件的項目數。Dim customerOrderAfter1996 = From cust In customers _
Aggregate order In cust.Orders _
Into Count(order.OrderDate > #12/31/1996#)
Group:參考 Group By 或 Group Join 子句之群組結果的查詢結果。Group 函式只有在 Group By 或 Group Join 子句的 Into 子句中才有效。
LongCount:計算集合中的項目數。您可以提供選擇性的 Boolean 運算式,只計算集合中滿足條件的項目數。傳回 Long 的結果。
Max:計算集合的最大值,或計算針對集合中所有項目而提供的運算式。Dim customerMaxOrder = Aggregate order In orders _
Into MaxOrder = Max(order.Total)
Min:計算集合的最小值,或計算針對集合中所有項目而提供的運算式。Dim customerMinOrder = From cust In customers _
Aggregate order In cust.Orders _
Into MinOrder = Min(order.Total)
Sum:計算集合中所有項目的總和,或計算針對集合中所有項目而提供的運算式。Dim customerTotals = From cust In customers _
Aggregate order In cust.Orders _
Into Sum(order.Total)
建立使用者定義的彙總函式: 您可以在查詢運算式中包含自己的自訂彙總函式,方法是將擴充方法加入至 IEnumerable<(Of <(T>)>) 型別。接著,您的自訂方法就可以在參考您的彙總函式的可列舉集合上,執行計算或作業。
例如,下列程式碼範例顯示用於計算數值集合中間值的自訂彙總函式。Median 擴充方法有兩個多載。第一個多載會接受型別 IEnumerable(Of Double) 的集合,做為輸入。如果 Median 彙總函式是針對型別 Double 的查詢欄位進行呼叫,就會呼叫此方法。Median 方法的第二個多載可以傳遞任何泛型型別。Median 方法的泛型多載會採用第二個參數,該參數參考 Func(Of T, Double) Lambda 運算式,將型別的值 (根據集合) 投射為型別 Double 的對應值。接著將中間值的計算委派 (Delegate) 至 Median 方法的其他多載。Imports System.Runtime.CompilerServices
下列程式碼範例顯示在型別 Integer 的集合和型別 Double 的集合上,呼叫 Median 彙總函式的範例查詢。在型別 Double 的集合上呼叫 Median 彙總函式的查詢會呼叫 Median 方法的多載,接受型別 Double 的集合以做為輸入。 在型別 Integer 的集合上呼叫 Median 彙總函式的查詢,則會呼叫 Median 方法的泛型多載。
Module UserDefinedAggregates
' Calculate the median value for a collection of type Double.
Function Median(ByVal medianAggregate As IEnumerable(Of Double)) As Double
If medianAggregate.Count = 0 Then
Throw New InvalidOperationException("Cannot compute median for an empty set.")
End If
Dim sortedList = From number In medianAggregate Order By number
Dim medianValue As Double
Dim itemIndex = CInt(Int(sortedList.Count / 2))
If sortedList.Count Mod 2 = 0 Then
' Even number of items in list.
medianValue = ((sortedList(itemIndex) + sortedList(itemIndex - 1)) / 2)
Else
' Odd number of items in list.
medianValue = sortedList(itemIndex)
End If
Return medianValue
End Function
' "Cast" the collection of generic items as type Double and call the
' Median() method to calculate the median value.
Function Median(Of T)(ByVal medianAggregate As IEnumerable(Of T), _
ByVal selector As Func(Of T, Double)) As Double
Return (From element In medianAggregate Select selector(element)).Median()
End Function
End ModuleModule Module1
Sub Main()
Dim numbers1 As Integer() = New Integer() {1, 2, 3, 4, 5}
Dim query1 = Aggregate num In numbers1 Into Median(num)
Console.WriteLine("Median = " & query1)
Dim numbers2 As Double() = New Double() {1.9, 2, 8, 4, 5.7, 6, 7.2, 0}
Dim query2 = Aggregate num In numbers2 Into Median()
Console.WriteLine("Median = " & query2)
End Sub
End Module
八、Distinct 子句:限制目前範圍變數的值,以免後續查詢子句中出現重複的值。
您可以使用 Distinct 子句傳回只含唯一項目的清單。Distinct 子句會使查詢忽略重複的查詢結果。Distinct 子句會套用至 Select 子句所指定之所有傳回欄位中的重複值。如果未指定 Select 子句,則 Distinct 子句會套用至 From 子句中所識別查詢的範圍變數。如果範圍變數並非不變的型別,則只有當型別的所有成員都符合現有的查詢結果時,查詢才會忽略查詢結果。Distinct
Dim customerOrders = From cust In customers, ord In orders _
Where cust.CustomerID = ord.CustomerID _
Select cust.CompanyName, ord.OrderDate _
Distinct
九、Let 子句:計算出一個值並將該值指派給查詢中的新變數。Let variable = expression [, ...]
Let 子句可以讓您計算每個查詢結果的值並使用別名參考這些值。別名可以用在其他子句中,例如 Where 子句。Let 子句可以讓您建立較易讀取的查詢陳述式,因為您可以指定查詢中包含之運算式子句的別名,並且在每次使用運算式子句的時候取代此別名。
您可以在 Let 子句中包含任意數量的 variable 和 expression 指派。請使用逗號 (,) 分隔每個指派。
下列程式碼範例使用 Let 子句計算產品的 10 % 折扣。Dim discountedProducts = From prod In products _
Let Discount = prod.UnitPrice * 0.1 _
Where Discount >= 50 _
Select prod.ProductName, prod.UnitPrice, Discount
For Each prod In discountedProducts
Console.WriteLine("Product: {0}, Price: {1}, Discounted Price: {2}", _
prod.ProductName, prod.UnitPrice.ToString("$#.00"), _
(prod.UnitPrice - prod.Discount).ToString("$#.00"))
Next
十、Skip 子句:略過集合中指定的項目數目,然後傳回其餘項目。Skip count
Skip 子句會使查詢略過結果清單開頭的項目並傳回剩餘項目。略過的項目數是由 count 參數識別。
您可以在查詢的任何區段搭配使用 Skip 子句和 Take 子句,以傳回某個範圍的資料。若要這樣做,請傳遞所需範圍中第一個項目的索引給 Skip 子句,並傳遞範圍的大小給 Take 子句。
當您在查詢中使用 Skip 子句時,可能還需要確保結果的傳回順序可讓 Skip 子句略過所要的結果。
您可以使用 SkipWhile 子句,指定只略過符合所指定條件的特定項目。
下列程式碼範例會搭配使用 Skip 子句和 Take 子句,以頁面為單位傳回查詢資料。GetCustomers 函式會使用 Skip 子句一直略過清單中的客戶直到遇到所提供的起始索引值,然後使用 Take 子句自該索引值起傳回一頁的客戶。Public Sub PagingSample()
Dim pageNumber As Integer = 0
Dim pageSize As Integer = 10
Dim customersPage = GetCustomers(pageNumber * pageSize, pageSize)
Do While customersPage IsNot Nothing
Console.WriteLine(vbCrLf & "Page: " & pageNumber + 1 & vbCrLf)
For Each cust In customersPage
Console.WriteLine(cust.CustomerID & ", " & cust.CompanyName)
Next
Console.WriteLine(vbCrLf)
pageNumber += 1
customersPage = GetCustomers(pageNumber * pageSize, pageSize)
Loop
End Sub
Public Function GetCustomers(ByVal startIndex As Integer, _
ByVal pageSize As Integer) As List(Of Customer)
Dim customers = GetCustomerList()
Dim returnCustomers = From cust In customers _
Skip startIndex Take pageSize
If returnCustomers.Count = 0 Then Return Nothing
Return returnCustomers
End Function
十一、Skip While 子句:一直略過集合中的項目,直到指定的條件不是 true,然後傳回剩餘項目。Skip While expression
Skip While 子句會自查詢結果開頭起一直略過項目,直到提供的 expression 傳回 false 為止。在 expression 傳回 false 之後,查詢會傳回所有剩餘項目。傳回剩餘結果時會忽略 expression。
Skip While 子句跟Where 子句有個不同點,即 Where 子句可用來排除查詢中所有不符合特定條件的項目。Skip While 子句則只會排除在第一次不符合條件之前遇到的項目。當您使用已排序的查詢結果時,Skip While 子句會很有幫助。
您可以使用 Skip 子句,略過查詢結果的前幾筆結果。
下列程式碼範例會使用 Skip While 子句一直略過結果,直到找到第一個美國客戶為止。Public Sub SkipWhileSample()
Dim customers = GetCustomerList()
' Return customers starting from the first U.S. customer encountered.
Dim customerList = From cust In customers _
Order By cust.Country _
Skip While IsInternationalCustomer(cust)
For Each cust In customerList
Console.WriteLine(cust.CompanyName & vbTab & cust.Country)
Next
End Sub
Public Function IsInternationalCustomer(ByVal cust As Customer) As Boolean
If cust.Country = "USA" Then Return False
Return True
End Function
十二、Take 子句:自集合的開頭起連續傳回所指定數目的項目。Take count
Take 子句會使查詢自結果清單開頭起,連續加入所指定數目的項目。要加入的項目數是由 count 參數指定。
您可以在查詢的任何區段搭配使用 Take 子句和 Skip 子句,以傳回某個範圍的資料。若要這樣做,請傳遞所需範圍中第一個項目的索引給 Skip 子句,並傳遞範圍的大小給 Take 子句。在此情況下,Take 子句必須指定在 Skip 子句之後。
當您在查詢中使用 Take 子句時,可能還需要確保結果的傳回順序可讓 Take 子句加入所要的結果。
您可以使用 TakeWhile 子句,指定只傳回符合所指定條件的特定項目。
下列程式碼範例會搭配使用 Take 子句和 Skip 子句,以頁面為單位傳回查詢資料。GetCustomers 函式會使用 Skip 子句一直略過清單中的客戶直到遇到所提供的起始索引值,然後使用 Take 子句自該索引值起傳回一頁的客戶。Public Sub PagingSample()
Dim pageNumber As Integer = 0
Dim pageSize As Integer = 10
Dim customersPage = GetCustomers(pageNumber * pageSize, pageSize)
Do While customersPage IsNot Nothing
Console.WriteLine(vbCrLf & "Page: " & pageNumber + 1 & vbCrLf)
For Each cust In customersPage
Console.WriteLine(cust.CustomerID & ", " & cust.CompanyName)
Next
Console.WriteLine(vbCrLf)
pageNumber += 1
customersPage = GetCustomers(pageNumber * pageSize, pageSize)
Loop
End Sub
Public Function GetCustomers(ByVal startIndex As Integer, _
ByVal pageSize As Integer) As List(Of Customer)
Dim customers = GetCustomerList()
Dim returnCustomers = From cust In customers _
Skip startIndex Take pageSize
If returnCustomers.Count = 0 Then Return Nothing
Return returnCustomers
End Function
十三、Take While 子句:一直包含集合中的項目直到指定的條件不是 true,然後略過剩餘項目。Take While expression
Take While 子句會自查詢結果開頭起一直包含項目,直到提供的 expression 傳回 false 為止。在 expression 傳回 false 之後,查詢會略過所有剩餘項目。傳回剩餘結果時會略過 expression。
Take While 子句跟Where 子句有個不同點,即 Where 子句可用來包含查詢中所有符合特定條件的項目。Take While 子句則只會包含在第一次不合條件之前遇到的項目。當您使用已排序的查詢結果時,Take While 子句會很有幫助。
下列程式碼範例會使用 Take While 子句擷取結果,直到找到第一個沒有任何訂單的客戶為止。Public Sub TakeWhileSample()
Dim customers = GetCustomerList()
' Return customers until the first customer with no orders is found.
Dim customersWithOrders = From cust In customers _
Order By cust.Orders.Count Descending _
Take While HasOrders(cust)
For Each cust In customersWithOrders
Console.WriteLine(cust.CompanyName & " (" & cust.Orders.Length & ")")
Next
End Sub
Public Function HasOrders(ByVal cust As Customer) As Boolean
If cust.Orders.Length > 0 Then Return True
Return False
End Function
頭快爆了,大部份重點都加進來了,就等慢慢消化吸收了!
LINQ(Language-Integrated Query)是VS2008和Framework 3.5中的突破性創舉,是一系列擴充方法的組合,它的核心是System.Collection.Generic命名空間中,名稱為IEnumerable(T)這個型別,其中所定義的方法成員,成了LINQ資料查詢技術的基礎,可適用於各種型態的資料來源的存取操作,包括SQL Server資料庫、XML文件、ADO.NET Dataset、文字檔、陣列、以及任何支援IEnumerable或泛型IEnumerable(T)介面的物件組成的集合。
當有一陣列內容為:Dim sFruit As String() = {"葡萄", "香蕉", "哈蜜瓜", "香瓜", "棷子", "蘋果", "木瓜"}
若要找出以"瓜"為結尾的陣列元素,過去的寫法通常是用迴圈來取得(為搭配後面的程式,此處用兩組迴圈完成,而不是直接以一組迴圈取得。第一組迴圈為主要取得符合條件的元素陣列,在後續程式中,將會被LINQ寫法取代):Dim s As String = ""
若改為應用IEnumerable時,則可寫成:
Dim myEnumFruit As New ArrayList
For Each myFruit As String In sFruit
If myFruit.EndsWith("瓜") Then
myEnumFruit.Add(myFruit)
End If
Next
Dim s As String = ""
For Each myFruit As String In myEnumFruit
s &= myFruit & vbCrLf
Next
MsgBox(s)Dim myEnumFruit As IEnumerable(Of String) = sFruit.Where(Function(fruit) fruit.EndsWith("瓜"))
上面程式碼,當執行更為複雜的查詢運算時,程式會變得更加複雜而不易理解。
Dim s As String = ""
For Each myFruit As String In myEnumFruit
s &= myFruit & vbCrLf
Next
MsgBox(s)
而若直接以LINQ寫法來處理時,將上述第一行程式碼改為:Dim myEnumFruit = From fruit In sFruit Where fruit.EndsWith("瓜") Select fruit
因為採用與SQL類似的From、Where、Select...等,讓程式設計時,針對各種不同的資料來源,可以運用統一的資料存取模型去操作,不必再去記一堆針對不同資料來源的處理方式,也不必再去理會那複雜而難以理解的IEnumerable寫法,而只需要將心力花費在程式的實際應用面部份即可。
然而,要注意的是,上頭LINQ寫法中的myEnumFruit這個查詢變數本身並不會採取任何動作,也不會傳回任何資料,它只會儲存查詢定義,真正負責查詢的是後面的For Each迴圈。因此,上述寫法稱為『延後執行』。
而若是要改寫為『立即執行』方式,則可如下:Dim myEnumFruit As List(Of String) = (From fruit In sFruit Where fruit.EndsWith("瓜") Select fruit).ToList
關於『延後執行』與『立即執行』的差異,由下列兩組程式便可看出:
一、延後執行:
二、立即執行:
Dim sFruit As String() = {"葡萄", "香蕉", "哈蜜瓜", "香瓜", "棷子", "蘋果", "木瓜"}
Dim myEnumFruit = From fruit In sFruit Where fruit.EndsWith("瓜") Select fruit
sFruit(1) = "胡瓜" '因是延後執行, 這項內容改變, 將導致後續結果也跟著改變, 會在結果中出現"胡瓜"這一項
Dim s As String = ""
For i As Integer = 0 To myEnumFruit.Count - 1
s &= myEnumFruit(i) & vbCrLf
Next
MsgBox(s)
Dim sFruit As String() = {"葡萄", "香蕉", "哈蜜瓜", "香瓜", "棷子", "蘋果", "木瓜"}
Dim myEnumFruit As List(Of String) = _
(From fruit In sFruit Where fruit.EndsWith("瓜") Select fruit).ToList
sFruit(1) = "胡瓜" '因是立即執行, 這項內容改變, 並沒有影響後續結果, 因此"胡瓜"並沒有在結果中出現
Dim s As String = ""
For i As Integer = 0 To myEnumFruit.Count - 1
s &= myEnumFruit(i) & vbCrLf
Next
MsgBox(s)
運用上述LINQ技術,應引用下面兩個命名空間:Imports System.Collections.Generic
不過,似乎VB2008已貼心的自動引入,即使我們在程式中沒有打入這兩行引入命名空間程式碼,亦可正常執行。
Imports System.Linq
LINQ技術包括三個部份,LINQ to Objects、LINQ to XML、LINQ to ADO.NET(含LINQ to SQL及LINQ to Dataset)。
以下為公開資訊觀測站裡的財務分析資料所列出者,包括:
如何運用?以後再研究!現金流量比率 = 營業活動淨現金流量 / 流動負債
現金流量允當比率 = 最近五年度營業活動淨現金流量 / 最近五年度(資本支出 + 存貨增加額 + 現金股利)
現金再投資比率 = (營業活動淨現金流量 - 現金股利) / (固定資產毛額 + 長期投資 + 其他資產 + 營運資金)
相關連結:財務報表分析
每股盈餘(Earnings Per Share,簡稱EPS),其公式為:
其中,需要兩項資訊,即稅後純益與本年度流通在外的股份加權平均數。每股盈餘(EPS) = (本年度稅後純益 – 特別股股利) / 本年度流通在外的股份加權平均數
到公開資訊觀測站中,以2324查取,
以95年第四季損益表查入,不必再經過計算,可直接查得每股盈餘:2.35。至於若要自行計算,那就得先查出本年度流通在外的股份加權平均數才行,這我不會。
這個部份的數據,並沒有一定標準存在。主要應用,都是針對個股在不同年度間的互相比較,或與相同性質之同業間的互相比較為主。
相關連結:獲利能力分析
稅後純益率(Net profit ratio),其公式為:
其中,需要兩項資訊,即稅後純益與營業收入淨額。稅後純益率 = 稅後純益 / 營業收入淨額 *100%
到公開資訊觀測站中,以2324查取,
以95年第四季損益表查入,可得本期淨利(淨損):8751466、營業收入合計:303070667。如此算得稅後純益率為:2.89%
後一項數據,便是公開資訊觀測站中常用報表頁籤中的財務分析資料所列出者。
這個部份的數據,並沒有一定標準存在。主要應用,都是針對個股在不同年度間的互相比較,或與相同性質之同業間的互相比較為主。
相關連結:獲利能力分析
總資產報酬率(Return on total assets)(ROA),其公式為:
其中,需要兩項資訊,即年度利益與平均資產總額、本期淨利(淨損)(稅後純益)、利息費用、所得稅率。稅後總資產報酬率 = (稅後純益 + 利息費用 * (1-所得稅率)) / 平均資產總額 *100%
到公開資訊觀測站中,以2324查取,
以95年第四季資產負債表查入,可得95年度資產總計:154580205。94年度資產總計:121307588。其平均資產總計為:137943896.5。
以95年第四季損益表查入,可得本期淨利(淨損):8751466、利息費用:199781
再由95年第一季財務報告書之第25頁可找到仁寶之營利事業所得稅率為:25%。
(這部份是最麻煩的部份,必須各別仔細查表才能得知)
如此算得稅後純益總資產報酬率為:6.45%
此項數據,便是公開資訊觀測站中常用報表頁籤中的財務分析資料所列出者。
這個部份的數據,並沒有一定標準存在。主要應用,都是針對個股在不同年度間的互相比較,或與相同性質之同業間的互相比較為主。
而到此為止可以發現,絕大部份比率分析都可以在公開資訊觀測站裡的『常用報表』頁內的『財務分析資料』中找到已經計算完成的比率資訊,根本不必自己花時間再去尋找計算。尤其是碰到如上述需要另外查非表格式的第一季財務報告書中的營利事業所得稅,那就更費時費力了。
相關連結:獲利能力分析
股東權益(淨值)報酬率(Return on equity)(ROE),其公式為:
其中,需要兩項資訊,即年度利益與平均股東權益。而年度淨利,在本例中取繼續營業單位稅前淨利(淨損)(稅前淨益)或本期淨利(淨損)。股東權益(淨值)報酬率 = (年度)淨利 / (平均)股東權益 *100%
到公開資訊觀測站中,以2324查取,
以95年第四季資產負債表查入,可得95年度股東權益總計:71233223。94年度股東權益總計:64794093。其平均股東權益為:68013658。
分子部份若取稅前淨利,以95年第四季損益表查入,可得繼續營業單位稅前淨利(淨損):9236027。如此算得稅前淨利股東權益報酬率為:13.60%
而分子部份若取稅後純益,查表可得本期淨利(淨損):8751466。如此算得稅後純益股東權益報酬率為:12.87%
後一項數據,便是公開資訊觀測站中常用報表頁籤中的財務分析資料所列出者。
這個部份的數據,並沒有一定標準存在。主要應用,都是針對個股在不同年度間的互相比較,或與相同性質之同業間的互相比較為主。
相關連結:獲利能力分析
股本(資本)報酬率,其公式為:
其中,需要兩項資訊,即年度利益與股本額。而年度利益,在本例中取營業淨利(淨損)或繼續營業單位稅前淨利(淨損)(稅前純益)。股本(資本)報酬率 = (年度)利益 / 股本額 *100%
到公開資訊觀測站中,以2324查取,
以95年第四季資產負債表查入,可得普通股股本(股本額):38114581。
分子部份若以營業利益,以95年第四季損益表查入,可得營業淨利(淨損):9236027。如此算得營業利益佔實收資本比率(營業淨利股本報酬率)為:24.23%
而分子部份若取稅前純益,查表可得繼續營業單位稅前淨利(淨損)(稅前純益):10391293。如此算得稅前純益佔實收資本比率(稅前淨利股本報酬率)為:27.26%
此兩項數據,皆與公開資訊觀測站中常用報表頁籤中的財務分析資料所列出者相符合。
這個部份的數據,並沒有一定標準存在。主要應用,都是針對個股在不同年度間的互相比較,或與相同性質之同業間的互相比較為主。
相關連結:獲利能力分析
獲利能力分析(Analysis of the Ability to Benefit)(Profitability analysis) 可針對三部份來探討:
報酬對投資的比率,即平均每投資一元(股本、股東權益、資產總額)可獲多少百分比的利益報酬(營業淨利、稅前淨利、稅後純益)。投資報酬率越大,獲利能力越高;投資報酬率越小,獲利能力越低。
可依投資種類而分成三種:投資報酬率 = 報酬 / 投資 *100%
股本(資本)報酬率 = (年度)利益 / 股本額 *100%
股本額,是指公司期末實際發行並已認足股款的實繳股本,或指上述實繳股本的全年加權平均數。
而依利益種類,可再區分為以下三種:股東權益(淨值)報酬率(Return on equity)(ROE) = (年度)淨利 / (平均)股東權益 *100%
總資產(本)報酬率(Return on total assets)(ROA)
(營利事業所得稅率,要上觀測站去查)財務槓桿指數 = 股東權益報酬率 / 總資產報酬率
財務槓桿因素 = 股東權益報酬率 - 總資產報酬率
平均每銷貨一元的營業收入(營業收入淨額)可獲得多少百分比的利益或利潤(營業毛利、營業淨利、稅前淨利、稅後純益)。比率越大,獲利能力越高;比率越小,獲利能力越低。
每股盈餘(Earnings Per Share,簡稱EPS),是用以顯示公司本年度平均每一普通股可獲多少盈餘報酬(稅後純益)的比率。分析時一般儘以普通股為對象,特別股並不包含在內;這是因為特別股一般只有分配定額股利的權利,性質較似公司債,因此計算時需將之減除。每股盈餘(EPS) = (本年度稅後純益(Net income) – 特別股股利(preferred stock dividends)) / 本年度流通在外的股份加權平均數(Weighted average outstanding shares)
每股股利,則是每股股份(本年度流通在外的股份加權平均數)可以發放股利(現金股利或股票股利)的金額。每股股利 = 股利 / 股數
本益比(Price-Earnings Ratio,簡稱P/E Ratio),是指每股市價對每股盈餘的比率。本利比,則是每股市價對每股股利的比率。本益比(P/E Ratio) = 每股市價 / 每股盈餘 本利比 = 每股市價 / 每股股利
相關連結:財務報表分析
存貨週轉率(Average inventory turnover rate)其公式為:
其中,需要兩項資訊,即營業成本合計(或銷貨成本)與存貨。存貨週轉率(次) = 銷貨成本 / 平均存貨
= 銷貨成本 / ((期初存貨+期末存貨)/2)
以95年第一季資產負債表查入,可得95年第一季存貨:8926264。
以95年第一季損益表查入,可得95年第一季營業成本合計:56608000。如此算得95年第一季存貨週轉率為:6.34次,換算年度存貨週轉率為(乘以4):25.37次。
以95年第二季資產負債表查入,可得95年第二季存貨:10313918。
以95年第二季損益表查入,可得95年第二季營業成本合計:114357359。如此算得95年第二季存貨週轉率為:11.09次,換算年度存貨週轉率為(乘以2):22.18次。
以95年第三季資產負債表查入,可得95年第三季存貨:12269574。
以95年第三季損益表查入,可得95年第三季營業成本合計:190172263。如此算得95年第三季存貨週轉率為:15.50次,換算年度存貨週轉率為(乘以4/3):20.67次。
以95年第四季資產負債表查入,可得95年第四季存貨:10840473。而94年第四季存貨(期初):9614722。
以95年第四季損益表查入,可得95年第四季營業成本合計:288656861。如此算得95年第四季存貨週轉率為:28.22次,而也就等同於95年度的存貨週轉率。(這裡,採取期初期末之平均值算法,所得之結果則與公開資訊觀測站所提供之數據相同)
而此處若直接再加以計算其平均售貨日數 = 365 / 存貨週轉率 = 12.93。這個數字相當好,一般來說,如果超過60天以上,就算是較長期的平均售貨日數了,也就代表著庫存管控不良。
而若以年度存貨週轉率來做比較的話,以95年度簡明資產負債表(三年)及95年度簡明損益表(三年)查入,則會發現,簡明資產負債表中並無存貨項目。因此,此項分析仍得從上面的正式報表中來查。
以96年第一季資產負債表及96年第一季損益表查入,可得存貨:12327942,營業成本合計:92360342。如此算得96年第一季存貨週轉率為:7.49次,換算年度存貨週轉率為(乘以4):29.97次。
以96年第二季資產負債表及96年第二季損益表查入,可得存貨:13047114,營業成本合計:186497401。如此算得96年第二季存貨週轉率為:14.29次,換算年度存貨週轉率為(乘以2):28.59次。
以96年第三季資產負債表及96年第三季損益表查入,可得存貨:17800160,營業成本合計:296328909。如此算得96年第三季存貨週轉率為:16.65次,換算年度存貨週轉率為(乘以4/3):22.20次。
至於96年第四季資產負債表及96年第四季損益表什麼時候會公佈,依據規定,四月底前必須公佈前一年度之年度報表。
相關連結:經營效能分析
應收帳款週轉率(Receivables turnover rate),其公式為:
其中,需要兩項資訊,即營業收入(或銷貨淨額)與應收帳款淨額。應收帳款週轉率(次) = 銷貨淨額 / 平均應收帳款
= 銷貨淨額 / ((期初應收帳款+期末應收帳款)/2)
以95年第一季資產負債表查入,可得95年第一季應收帳款淨額+應收帳款_關係人淨額:38904743+579192=39483935。
以95年第一季損益表查入,可得95年第一季營業收入合計:59656195。如此算得95年第一季應收帳款週轉率為:1.51次,換算年度應收帳款週轉率為(乘以4):6.04次。
以95年第二季資產負債表查入,可得95年第二季應收帳款淨額+應收帳款_關係人淨額:36201032+626942=36827974。
以95年第二季損益表查入,可得95年第二季營業收入合計:120280280。如此算得95年第二季應收帳款週轉率為:3.27次,換算年度應收帳款週轉率為(乘以2):6.53次。
以95年第三季資產負債表查入,可得95年第三季應收帳款淨額+應收帳款_關係人淨額:46621437+540213=47161650。
以95年第三季損益表查入,可得95年第三季營業收入合計:199751299。如此算得95年第三季應收帳款週轉率為:4.24次,換算年度應收帳款週轉率為(乘以4/3):5.65次。
以95年第四季資產負債表查入,可得95年第四季應收帳款淨額+應收帳款_關係人淨額:60777982+693368=61471350(期末)。而94年第四季應收帳款淨額+應收帳款_關係人淨額:38091939+1058376=39150315(期初)。
以95年第四季損益表查入,可得95年第四季營業收入合計:303070667。如此算得95年第四季應收帳款週轉率為:6.02次,而也就等同於95年度的應收帳款週轉率。這裡,採用期初應收帳款淨額與期末應收帳款淨額之平均值來當分母,計算出之結果與公開資訊觀測站中的常用報表中的『財務分析資料』項目中所顯示的結果(6.02次)相同。
而此處若直接再加以計算其應收帳款收現日數 = 365 / 應收帳款週轉率 = 60.63,大約剛好2個月左右。這個數字還算不錯,一般來說,如果超過2.5個月,就算是較長期的應收款日數了,也就代表著出現呆帳的機率將會提高。
而若以年度應收帳款週轉率來做比較的話,以95年度簡明資產負債表(三年)及95年度簡明損益表(三年)查入,則會發現,簡明資產負債表中並無應收帳款項目。因此,此項分析仍得從上面的正式報表中來查。
以96年第一季資產負債表及96年第一季損益表查入,可得應收帳款淨額+應收帳款_關係人淨額:59891422+1612011=61503433,營業收入合計:96980442。如此算得96年第一季應收帳款週轉率為:1.58次,換算年度應收帳款週轉率為(乘以4):6.31次。
以96年第二季資產負債表及96年第二季損益表查入,可得應收帳款淨額+應收帳款_關係人淨額:63799750+1707503=65507253,營業收入合計:195856814。如此算得96年第二季應收帳款週轉率為:2.99次,換算年度應收帳款週轉率為(乘以2):5.98次。
以96年第三季資產負債表及96年第三季損益表查入,可得應收帳款淨額+應收帳款_關係人淨額:70920371+1201521=72121892,營業收入合計:311233016。如此算得96年第三季應收帳款週轉率為:4.32次,換算年度應收帳款週轉率為(乘以4/3):5.75次。
至於96年第四季資產負債表及96年第四季損益表什麼時候會公佈,依據規定,四月底前必須公佈前一年度之年度報表。
相關連結:經營效能分析
固定資產週轉率(Fixed assets turnover rate),其公式為:
其中,需要兩項資訊,即營業收入(或銷貨淨額)與固定資產總額。固定資產週轉率(次) = 銷貨淨額 / 平均固定資產
= 銷貨淨額 / ((期初固定資產+期末固定資產)/2)
以95年第一季資產負債表查入,可得95年第一季固定資產淨額:2594121。
以95年第一季損益表查入,可得95年第一季營業收入合計:59656195。如此算得95年第一季固定資產週轉率為:23次,換算年度固定資產週轉率為(乘以4):92次。
以95年第二季資產負債表查入,可得95年第二季固定資產淨額:2447541。
以95年第二季損益表查入,可得95年第二季營業收入合計:120280280。如此算得95年第二季固定資產週轉率為:49.1次,換算年度固定資產週轉率為(乘以2):98.3次。
以95年第三季資產負債表查入,可得95年第三季固定資產淨額:2417701。
以95年第三季損益表查入,可得95年第三季營業收入合計:199751299。如此算得95年第三季固定資產週轉率為:82.6次,換算年度固定資產週轉率為(乘以4/3):110.2次。
以95年第四季資產負債表查入,可得95年第四季固定資產淨額:2401584。
以95年第四季損益表查入,可得95年第四季營業收入合計:303070667。如此算得95年第四季固定資產週轉率為:126.2次,而也就等同於95年度的固定資產週轉率。
而若以年度固定資產週轉率來做比較的話,以95年度簡明資產負債表(三年)及95年度簡明損益表(三年)查入,可得:
94年固定資產淨額:2931242,94年營業收入:220902441。如此算得之94年度固定資產週轉率為:75.36次
95年固定資產淨額:2401584,95年營業收入:303070667。如此算得之95年度固定資產週轉率為:126.2次
由此,亦可看出仁寶在95年度的固定資產週轉率較94年度者為高,企業經營效能在提高中。
以96年第一季資產負債表及96年第一季損益表查入,可得固定資產淨額:2395239,營業收入合計:96980442。如此算得96年第一季固定資產週轉率為:40.49次,換算年度固定資產週轉率為(乘以4):161.96次。
以96年第二季資產負債表及96年第二季損益表查入,可得固定資產淨額:2380045,營業收入合計:195856814。如此算得96年第二季固定資產週轉率為:82.29次,換算年度固定資產週轉率為(乘以2):164.58次。
以96年第三季資產負債表及96年第三季損益表查入,可得期末資產總計:2485900,營業收入合計:311233016。如此算得96年第三季固定資產週轉率為:125.2次,換算年度固定資產週轉率為(乘以4/3):166.93次。
至於96年第四季資產負債表及96年第四季損益表什麼時候會公佈,依據規定,四月底前必須公佈前一年度之年度報表。
這裡的計算,分母已不再使用平均固定資產淨額了,而是直接取用當年度(或當季)固定資產淨額為分母來計算。
相關連結:經營效能分析
總資產週轉率(Total Assets Turnover Rate),其公式為:
其中,需要兩項資訊,即營業收入(或銷貨淨額)與期初資產總額、期末資產總額。總資產週轉率(次) = 營業收入(或銷貨淨額) / 平均資產總額
= 營業收入(或銷貨淨額) / ((期初資產總額+期末資產總額)/2)
到公開資訊觀測站中,以2324查取資產負債表與損益表時,損益表中的營業收入項目中若只有銷貨淨額的話,仍會總結成為營業收入項目中,因此,直接抓取『營業收入』項目使用即可。而至於期初資產總額,即為上一會計期間之資產總額,即,若是以季為單位計算即為上一季,而若是以年度為單位計算則為上一年度。
以94年第四季資產負債表查入,可得95年第一季期初資產總計:121307588。
以95年第一季資產負債表查入,可得95年第一季期末資產總計:125486464。
以95年第一季損益表查入,可得95年第一季營業收入合計:59656195。如此算得95年第一季總資產週轉率為:0.483次,換算年度總資產週轉率為(乘以4):1.934次。
以95年第二季資產負債表查入,可得95年第二季期末資產總計:125016403。
以95年第二季損益表查入,可得95年第二季營業收入合計:120280280。如此算得95年第二季總資產週轉率為:0.960次,換算年度總資產週轉率為(乘以2):1.921次。
以95年第三季資產負債表查入,可得95年第三季期末資產總計:132726696。
以95年第三季損益表查入,可得95年第三季營業收入合計:199751299。如此算得95年第三季總資產週轉率為:1.55次,換算年度總資產週轉率為(乘以4/3):2.067次。
以95年第四季資產負債表查入,可得95年第四季期末資產總計:154580205。
以95年第四季損益表查入,可得95年第四季營業收入合計:303070667。如此算得95年第四季總資產週轉率為:2.109次,而也就等同於95年度的總資產週轉率。
再以簡明損益表(三年)查得之95年度資料比對,與前面所查之95年第四季完全相同。
故,日後查尋損益表之資料來源時,若是第四季資料已出,則可直接取之;否則,將只能由最後發表的那一季資料來預估。但是,若要評估單季的週轉率,則需將本季累計營收減去上季累計營收,才是本季的實際營收。
而由上面計算中可以看到,總資產週轉率在逐季增加中。代表仁寶在95年這數季來在運用總資產的效率方面愈來愈高,這對企業的經營效能來說,是有利的。
而若以年度總資產週轉率來做比較的話,以95年度簡明資產負債表(三年)及95年度簡明損益表(三年)查入,可得:
94年期初資產總計(即93年期末資產總計):105884229,94年期末資產總計:121307588,94年營業收入:220902441。如此算得之94年度總資產週轉率為:1.945次
95年期初資產總計(即94年期末資產總計):121307588,95年期末資產總計:154580205,95年營業收入:303070667。如此算得之95年度總資產週轉率為:2.197次
由此,亦可看出仁寶在95年度的總資產週轉率較94年度者為高,企業經營效能在提高中。
以96年第一季資產負債表及96年第一季損益表查入,可得期末資產總計:154042684,營業收入合計:96980442。如此算得96年第一季總資產週轉率為:0.628次,換算年度總資產週轉率為(乘以4):2.514次。
以96年第二季資產負債表及96年第二季損益表查入,可得期末資產總計:160074098,營業收入合計:195856814。如此算得96年第二季總資產週轉率為:1.247次,換算年度總資產週轉率為(乘以2):2.494次。
以96年第三季資產負債表及96年第三季損益表查入,可得期末資產總計:168232137,營業收入合計:311233016。如此算得96年第三季總資產週轉率為:1.896次,換算年度總資產週轉率為(乘以4/3):2.528次。
至於96年第四季資產負債表及96年第四季損益表什麼時候會公佈,依據規定,四月底前必須公佈前一年度之年度報表。
不過,這裡的計算似乎有點小問題。按照定義上來說,應該分母是平均資產總額才對,也就是,應該是(期初資產總額+期末資產總額)/2。而所求出來的95年度的總資產週轉率為2.197次。但是,若我們直接查公開資訊觀測站,在常用報表頁籤中有個財務分析資料的項目,而依該項目查得的總資產週轉率卻為1.96次。很顯然,兩者間有差距。因此,我將分母部份改為當年之資產總計,而不去計算平均資產總計的話,結果就完全一樣了,也是1.96。故,應該也可以化繁為簡,只取當年度資產總計為分母來計算即可。
相關連結:經營效能分析
速動比率(Quick Raio),其公式為:
其中,速動資產,乃指現金、有價證券、應收票據、及應收帳款等各項可迅速變現,而用以支付流動負債的資產。速動比率 = 速動資產 / 流動負債 *100%
問題來了,在資產負債表中,可以找到現金、應收票據、及應收帳款,但找不到有價證券。是否直接忽略有價證券這一項呢?其實,速動資產也可以用下面公式表達:
但,同樣的,在資產負債表中找得到存貨,但找不到預付費用,那就只好將預付費用省去了。因此,這裡需要三項資訊,即流動資產、存貨與流動負債。速動資產(Quick Assets) = 流動資產(Current Assets) - 存貨(Inventories) - 預付費用(Prepaid Expenses)
到公開資訊觀測站中,以2324查取資產負債表時,
以95年第四季查入,可得流動資產:107775321,存貨:10840473,流動負債:83131470。如此算得速動比率為:116.6%
按照標準,比率在100%以上,代表短期變現能力不錯、有應付緊急償債的能力。
至於96年第四季報表,依據規定,四月底前必須公佈前一年度之年度報表。
相關連結:短期償債能力分析
固定資產對長期資金比率(Fix Assets To Long-term Funds Ratio),其公式為:
其中,需要三項資訊,即固定資產、長期負債與股東權益總額。固定資產對長期資金比率 = 固定資產 / (長期負債 + 股東權益總額) *100%
到公開資訊觀測站中,以2324查取資產負債表時,
以95年第四季查入,可得固定資產淨額:2401584,長期負債:0,股東權益總計:71233223。如此算得固定資產對長期資金比率為:3.37%
按照標準,比率在100%以下,並未達到警戒線。
至於96年第四季報表,依據規定,四月底前必須公佈前一年度之年度報表。
相關連結::財務結構分析
資本總額比率(Capitalization Ratio),其公式為:
其中,需要兩項資訊,即長期負債與股東權益總額。資本總額比率 = 長期負債 / (長期負債 + 股東權益總額) *100%
到公開資訊觀測站中,以2324查取資產負債表時,
以95年第四季查入,可得長期負債:0,股東權益總計:71233223。如此算得資本總額比率為:0%
按照標準,比率在35%以下,並未達到警戒線。
至於96年第四季報表,依據規定,四月底前必須公佈前一年度之年度報表。
相關連結:財務結構分析
企業籌措資金,購買各種營運資產,如固定資產、存貨等,經由生產、銷售等營業活動,產生各種營業收入;而收入再經過收款等營業活動,產生更多的營運資產,如應收帳款、應收票據、銀行存款、與現金等。而現金、銀行存款,可再用以購買存貨、固定資產,繼續生產、銷貨、收款等營業活動,循環不已。 因此,這種循環的期間愈短,表示企業運用各種營運資產的效率愈高,對企業也愈有利。而經營效能分析(Analysis of Operation Efficiency),最主要的就是使用資產週轉率來作為分析評估,其基本公式為: 其中,資產可代表各種營運資產,而企業若僅有銷貨收入時,一般則以銷貨收入淨額代替營業收入淨額。常用的各項週轉率如下: 一般評估而言,資產週轉率的值愈大,表示資產週轉率的次數愈多,企業運用各種營運資產的效率愈高,對企業自然愈有利。但因各行各業性質不同,欲以資產週轉率來評估公司運用營運資產是否具有效率,或營業收入各項營運資產是否保持合理關係,必須與行業性質相同或類似的同業,或是公司過去年度資產週轉率作比較,才較有意義。 另,在評估公司獲利能力時所用的兩項重要指標:投資報酬率與純益率,其與資產週轉率間是互有關聯的: 因此,一企業要追求利潤、提高投資報酬率,除可從提高純益率著手外,亦可從提高資產的利用率來提高投資報酬率。 相關連結:財務報表分析資產週轉率(次) = 營業收入淨額 / 資產平均額
總資產週轉率(次) = 銷貨淨額 / 平均資產總額
= 銷貨淨額 / ((期初資產總額+期末資產總額)/2)固定資產週轉率(次) = 銷貨淨額 / 平均固定資產
= 銷貨淨額 / ((期初固定資產+期末固定資產)/2)應收帳款週轉率(次) = 銷貨淨額 / 平均應收帳款
= 銷貨淨額 / ((期初應收帳款+期末應收帳款)/2)存貨週轉率(次) = 銷貨成本 / 平均存貨
= 銷貨成本 / ((期初存貨+期末存貨)/2)存貨週轉天數 = 360 / 存貨週轉率
總資產投資報酬率 = 稅後純益 / 總資產
= (稅後純益/銷貨) * (銷貨/總資產)
= 純益率 * 總資產週轉率
短期償債能力分析(Analysis of Short-Term Repayment Ability),是針對被分析公司的現金與短期內可以變現的各種資產,以及短期內到期而必須償還的各種負債,進行評估。雖某某企業可能獲利能力不錯,但卻可能因不能償還到期的負債而導致週轉不靈,以致無法繼續經營。因此,短期償債能力分析,實是企業體質健全與否的重要指標。 以下為常用的比率: 影響流動比率的主要因素,一般認為是營運周期、流動資產中的應收帳款數額、和存貨週轉速度。 少數不肖企業人士,可能利用會計原理,將各有關科目予以適當安排,使達到改善營運資金與流動比率的地位,以粉飾財務報表外觀,此即一般所謂的『窗飾』(Window dressing),因此必須小心。 流動比率也被稱為『營運資金比率』(working capital ratio),甚至逕以『營運資金』代替流動比率使用。實際上,流動資產大於流動負債的餘額,才稱為『營運資金』。(參考:財務狀況變動表) 影響速動比率可信度的重要因素是應收帳款的變現能力。 速動比率可以表達企業是否有應付緊急償債的能力。理論上,速動比率應較流動比率標準要求較低,只要速動比率達100%以上便稱理想,如能達50%~100%間亦屬尚可,唯在50%以下者表示迅速償債能力甚低。 應收帳款週轉率 存貨週轉率 相關連結:財務報表分析
流動比率越高,表示短期償債能力越高;流動比率越低,則短期償債能力越低。流動比率 = 流動資產 / 流動負債 *100%
流動資產中的某些項目在變現時可能有貶值之虞,因此推論出流動比率應超過200%方屬理想,但也不可一概而論。台灣企業與200%的理想相去甚遠,一般來說只有100%左右;而如低於100%以下,則表示短期償債能力過低,對債權人的權益,已缺乏保障。
速動資產,乃指現金、有價證券、應收票據、及應收帳款等各項可迅速變現,而用以支付流動負債的資產。 速動比率 = 速動資產 / 流動負債 *100%
應收帳款平均收回天數
存貨轉換期間
資本負債比率(Debt-to-Equity Ratio),其公式為:
其中,需要兩項資訊,即負債總額與股東權益總額。資本負債比率 = 負債總額 / 股東權益總額 *100%
我是財務報表分析之門外漢,以下,全是個人憑空思考路徑。將來,若有知識累積或觀念改變,將會回頭再來修正。觀看者若有正確觀念提供,尚請提出指教,謝謝!
到公開資訊觀測站中,以2324查取資產負債表時,
以95年第一季查入,可得負債總計:56988643,股東權益總計:68497821。如此算得資本負債比率為:83.2%
以95年第二季查入,可得負債總計:59913319,股東權益總計:65103084。如此算得資本負債比率為:92.0%
以95年第三季查入,可得負債總計:65120350,股東權益總計:67606346。如此算得資本負債比率為:96.3%
以95年第四季查入,可得負債總計:83346982,股東權益總計:71233223。如此算得資本負債比率為:117.0%
再以簡明資產負債表(三年)查得之95年度資料比對,與前面所查之95年第四季完全相同。
故,日後查尋此項分析之資料來源時,若是第四季資料已出,則可直接取之;否則,將只能由最後發表的那一季資料來預估。
按照標準,比率皆在200%以下,並未達到警戒線。
而由上面計算中可以看到,資本負債比率在逐季增加中。代表仁寶在95年這數季來一直在增加財務槓桿率中。
增加財務槓桿率,若經營得當,可創造出更多的收益;而若經營不當,則可能導致倒閉的命運。
但以低於200%的狀況來論,尚在安全警戒範圍內,資產結構尚屬正常。至於增加資本負債比率後,是否有回饋到營收或稅後盈餘上,那就得看其他分析項目了。
以96年第一季查入,可得負債總計:79431213,股東權益總計:74611471。如此算得資本負債比率為:106.5%
以96年第二季查入,可得負債總計:88306680,股東權益總計:71767418。如此算得資本負債比率為:123.0%
以96年第三季查入,可得負債總計:92887116,股東權益總計:75345021。如此算得資本負債比率為:123.3%
至於96年第四季(這個連結目前尚無用處)報表什麼時候會公佈,依據規定,四月底前必須公佈前一年度之年度報表。
相關連結:財務結構分析
參考這兩篇:
http://skyvee.net/2007/05/blogger-funp.html
http://skyvee.net/2007/08/funp-push.html
I.首先 在 <head> </head> 之間, 加入這段程式碼.
<script language='JavaScript' src='http://bloggertips.googlecode.com/files/funp_button2.js'/>
II.以下三選一
如果要把推文按鈕加在文章標題列, 則在 <h3 class='post-title'> 後, 加入以下程式碼
<script>funp_genButton("<data:post.url/>");</script>
如果想放在文章左側, 則在<p><data:post.body/></p> 之前, 加入以下程式碼
<div style='float:left;margin-left:10px;'>
<script>funp_genButton(" ");</script>
</div>
如果是文章右側, 則在<p><data:post.body/></p> 之前, 加入以下程式碼
<div style='float:right;margin-right:10px;'>
<script>funp_genButton("<data:post.url/>");</script>
</div>
SD協會並且要求記憶卡製造商必須在SDHC外觀清楚標示SD Speed Class等級。
有玩相機的人,大多都會知道,相機的光圈值,常見的有:
F1.4 / F2 / F2.8 / F4 / F5.6 / F8 / F11 / F16 / F22 / F32
這些光圈數值幾乎是被學攝影者所直接背下來的,但是,很少人知道它們之間真正的關係。
當然,稍微懂的人都知道,每組鄰近一個光圈值之間,都有一格(或一級)的進光量差異。
即,每差一格,在固定時間內的進光量就差一倍。
光圈數值越小,代表光圈開得越大,進光量也就比下一格多一倍。
那麼,這些數字間究竟是什麼關係,為什麼數值越小光圈開越大,又為什麼進光量會每一格差一倍呢?
原來,這些數值的計算法,是由下面公式得出來的:
光圈值(F Number) = 鏡頭焦距(mm) / 光圈口徑(mm)
所以,我們若以標準鏡頭焦距50mm當標準來計算,
這樣,當光圈口徑也等於50mm時,光圈值就等於F1了。
那麼,下一個一半進光量的光圈值該是多少呢?
很簡單,會數學或會程式的人一定知道,就是用面積比例下去算了:
1. 半徑:50 / 2=25
2. 面積:25^2 * 3.14159...
3. 面積一半:25^2 * 3.14159... / 2
4. 還原回一半面積的半徑值:sqr(25^2 * 3.14159... / 2 / 3.14159...) = sqr(25^2 / 2)
5. 再轉成直徑:sqr(25^2 /2) *2 = sqr(50^2 / 8) *2 = sqr(50^2 /2)
好啦,所以,下一個一半進光量的光圈口徑就是sqr(50^2 / 2)了,
那麼,其光圈值就是:50 / sqr(50^2 / 2)
我們用VB6簡單寫個程式,把所有一系列的光圈值列出來:
Private Sub Command1_Click()
a = 50: b = 50
Debug.Print "光圈口徑(mm)", "光圈值(F)"
For i = 1 To 11
Debug.Print Format(b, "#0.00"), Format(a / b, "#0.00")
b = Sqr(b ^ 2 / 2)
Next
End Sub
這樣,得到的答案是:
光圈口徑(mm) 光圈值(F)
50.00 1.00
35.36 1.41
25.00 2.00
17.68 2.83
12.50 4.00
8.84 5.66
6.25 8.00
4.42 11.31
3.13 16.00
2.21 22.63
1.56 32.00
當然,光圈值的標示只是個大略值,方便攝影者記憶而已!
將上面答案的小數第二位或連同小數第一位去掉,是不是就跟最上面提到的那排光圈值一樣了!
以後,再看到這些光圈值時,心中疑惑應該就會降到最低了吧!