前段時間發現,Blogjava的登錄頁面居然沒有驗證碼了,圖片顯示錯誤,無法登錄,預感這個地方要涼,只好到處找替代,但沒找到好用的博客,github是一個選項,但似乎不是很適合做博客。
現在終于又可以登錄了,不過首頁居然只剩一篇文章,我以為數據都沒了,登錄發現還是有的,不過太讓人不放心了。
2007年9月18日 #
其實我覺得用java結合SQL來做同樣的事情更簡單,但是EXCEL的好處是不用編程,雖然里面有好多陷阱,但是掌握之后能夠熟練運用還是比每次都編個程序更簡單。VLOOKUP函數的使用比較復雜,搞了好久都不明白,終于找到了下面這篇文章,解決了很多問題。
以下是轉載文章,原來的出處不知道是哪里,應該是來自
VLOOKUP函數是Excel中幾個最重函數之一,為了方便大家學習,蘭色幻想特針對VLOOKUP函數的使用和擴展應用,進行一次全面綜合的說明。本文為入門部分
一、入門級
VLOOKUP是一個查找函數,給定一個查找的目標,它就能從指定的查找區域中查找返回想要查找到的值。它的基本語法為:
VLOOKUP(查找目標,查找范圍,返回值的列數,精確OR模糊查找)
下面以一個實例來介紹一下這四個參數的使用
例1:如下圖所示,要求根據表二中的姓名,查找姓名所對應的年齡。
公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)
參數說明:
1 查找目標:就是你指定的查找的內容或單元格引用。本例中表二A列的姓名就是查找目標。我們要根據表二的“姓名”在表一中A列進行查找。
公式:B13 =VLOOKUP(A13,$B$2:$D$8,3,0)
2 查找范圍(VLOOKUP(A13,$B$2:$D$8,3,0) ): 指定了查找目標,如果沒有說從哪里查找,EXCEL肯定會很為難。所以下一步我們就要指定從哪個范圍中進行查找。VLOOKUP的這第二個參數可以從一個 單元格區域中查找,也可以從一個常量數組或內存數組中查找。本例中要從表一中進行查找,那么范圍我們要怎么指定呢?這里也是極易出錯的地方。大家一定要注 意,給定的第二個參數查找范圍要符合以下條件才不會出錯:
A 查找目標一定要在該區域的第一列。本例中查找表二的姓名,那么姓名所對應的表一的姓名列,那么表一的姓名列(列)一定要是查找區域的第一列。象本例中,給定的區域要從第二列開始,即$B$2:$D$8,而不能是$A$2:$D$8。因為查找的“姓名”不在$A$2:$D$8區域的第一列。
B 該區域中一定要包含要返回值所在的列,本例中要返回的值是年齡。年齡列(表一的D列)一定要包括在這個范圍內,即:$B$2:$D$8,如果寫成$B$2:$C$8就是錯的。
3 返回值的列數(B13 =VLOOKUP(A13,$B$2:$D$8,3,0))。這是VLOOKUP第3個參數。它是一個整數值。它怎么得來的呢。它是“返回值”在第二個參數給定的區域中的列數。本例中我們要返回的是“年齡”,它是第二個參數查找范圍$B$2:$D$8的第3列。這里一定要注意,列數不是在工作表中的列數(不是第4列),而是在查找范圍區域的第幾列。如果本例中要是查找姓名所對應的性別,第3個參數的值應該設置為多少呢。答案是2。因為性別在$B$2:$D$8的第2列中。
4 精確OR模糊查找(VLOOKUP(A13,$B$2:$D$8,3,0) ),最后一個參數是決定函數精確和模糊查找的關鍵。精確即完全一樣,模糊即包含的意思。第4個參數如果指定值是0或FALSE就表示精確查找,而值為1 或TRUE時則表示模糊。這里蘭色提醒大家切記切記,在使用VLOOKUP時千萬不要把這個參數給漏掉了,如果缺少這個參數默為值為模糊查找,我們就無法精確查找到結果了。
好了,關于VLOOKUP函數的入門級應用就說到這里,VLOOKUP函數可不只是這么簡單的查找,我們講的還只是1/10的用法。其他的沒法在一篇文章中說明。敬請期待“VLOOKUP的使用方法-進階篇”吧。
上一講咱們學習了VLOOKUP的基本用法和示例,本講將介紹VLOOKUP在使用中的一些小技巧。
Excel函數速成教程全系列(包括VLOOKUP函數,IF函數,offset函數,sumif函數等66個函數)預計6月初全部錄制完成,現已在淘寶開始預訂(8折優惠),地址:http://item.taobao.com/item.htm?id=17500884347
一、VLOOKUP多行查找時復制公式的問題
VLOOKUP函數的第三個參數是查找返回值所在的列數,如果我們需要查找返回多列時,這個列數值需要一個個的更改,比如返回第2列的,參數設置為2,如 果需要返回第3列的,就需要把值改為3。。。如果有十幾列會很麻煩的。那么能不能讓第3個參數自動變呢?向后復制時自動變為2,3,4,5。。。
在EXCEL中有一個函數COLUMN,它可以返回指定單元格的列數,比如
=COLUMNS(A1) 返回值1
=COLUMNS(B1) 返回值2
而單元格引用復制時會自動發生變化,即A1隨公式向右復制時會變成B1,C1,D1。。這樣我們用COLUMN函數就可以轉換成數字1,2,3,4。。。
例:下例中需要同時查找性別,年齡,身高,體重。
公式:=VLOOKUP($A13,$B$2:$F$8,COLUMN(B1),0)
公式說明:這里就是使用COLUMN(B1)轉化成可以自動遞增的數字。
二、VLOOKUP查找出現錯誤值的問題。
1、如何避免出現錯誤值。
EXCEL2003 在VLOOKUP查找不到,就#N/A的錯誤值,我們可以利用錯誤處理函數把錯誤值轉換成0或空值。
即:=IF(ISERROR(VLOOKUP(參數略)),"",VLOOKUP(參數略)
EXCEL2007,EXCEL2010中提供了一個新函數IFERROR,處理起來比EXCEL2003簡單多了。
IFERROR(VLOOKUP(),"")
2、VLOOKUP函數查找時出現錯誤值的幾個原因
A、實在是沒有所要查找到的值
B、查找的字符串或被查找的字符中含有空格或看不見的空字符,驗證方法是用=號對比一下,如果結果是FALSE,就表示兩個單元格看上去相同,其實結果不同。
C、參數設置錯誤。VLOOKUP的最后一個參數沒有設置成1或者是沒有設置掉。第二個參數數據源區域,查找的值不是區域的第一列,或者需要反回的字段不在區域里,參數設置在入門講里已注明,請參閱。
D、數值格式不同,如果查找值是文本,被查找的是數字類型,就會查找不到。解決方法是把查找的轉換成文本或數值,轉換方法如下:
文本轉換成數值:*1或--或/1
數值轉抱成文本:&""
VLOOKUP函數的初級篇就說到這里了,咱們下一講將介紹VLOOKUP的模糊查找有、反向查找等。
在學習了VLOOKUP的入門和初級篇后,本文將帶將大家學習VLOOKUP的進階篇:VLOOKUP的模糊查找。
一、字符的模糊查找
在A列我們知道如何查找型號為“AAA”的產品所對應的B列價格,即:
=VLOOKUP(C1,A:B,2,0)
如果我們需要查找包含“AAA”的產品名稱怎么表示呢?如下圖表中所示。
公式=VLOOKUP("*"&A10&"*",A2:B6,2,0)
公式說明:VLOOKUP的第一個參數允許使用通配符“*”來表示包含的意思,把*放在字符的兩邊,即"*" & 字符 & "*"。
二、數字的區間查找
數字的區間查找即給定多個區間,指定一個數就可以查找出它在哪個區間并返回這個區間所對應的值。
在VLOOKUP入門中我們提示VLOOKUP的第4個參數,如果為0或FALSE是精確查找,如果是1或TRUE或省略則為模糊查找,那么實現區間查找正是第4個參數的模糊查找應用。
首先我們需要了解一下VLOOKUP函數模糊查找的兩個重要規則:
1、引用的數字區域一定要從小到大排序。雜亂的數字是無法準確查找到的。如下面A列符合模糊查找的前題,B列則不符合。
2、模糊查找的原理是:給一定個數,它會找到和它最接近,但比它小的那個數。詳見下圖說明。
最后看一個實例:
例:如下圖所示,要求根據上面的提成比率表,在提成表計算表中計算每個銷售額的提成比率和提成額。
公式:=VLOOKUP(A11,$A$3:$B$7,2)
公式說明:
1、上述公式省略了VLOOKUP最后一個參數,相當于把第四個參數設置成1或TRUE。這表示VLOOKUP要進行數字的區間查找。
2、圖中公式中在查找5000時返回比率表0所對應的比率1%,原因是0和10000與5000最接近,但VLOOKUP只選比查找值小的那一個,所以公式會返回0所對應的比率1%。
前言:前面我們分別學習了VLOOKUP函數的入門、初級和進階篇。今天我們學習VLOOKUP函數的高級應用部分-VLOOKUP函數的數組應用。(本文由蘭色幻想原創,轉載請注明轉自excel精英培訓)
一、VLOOKUP的反向查找。
一般情況下,VLOOKUP函數只能從左向右查找。但如果需要從右向右查找,則需要把區域進行“乾坤大挪移”,把列的位置用數組互換一下。
例1:要求在如下圖所示表中的姓名反查工號。
公式:=VLOOKUP(A9,IF({1,0},B2:B5,A2:A5),2,0)
公式剖析:
1、這里其實不是VLOOKUP可以實現從右至右的查找,而是利用IF函數的數組效應把兩列換位重新組合后,再按正常的從左至右查找。
2、IF({1,0},B2:B5,A2:A5)這是本公式中最重要的組成部分。在EXCEL函數中使用數組時(前提時該函數的參數支持數組),返回的結 果也會是一個數組。這里1和0不是實際意義上的數字,而是1相關于TRUE,0相當于FALSE,當為1時,它會返回IF的第二個參數(B列),為0時返 回第二個參數(A列)。根據數組運算返回數組,所以使用IF后的結果返回一個數組(非單元格區域):{"張一","A001";"趙 三","A002";"楊五","A003";"孫二","A004"}
二、VLOOKUP函數的多條件查找。
VLOOKUP函數需要借用數組才能實現多條件查找。
例2:要求根據部門和姓名查找C列的加班時間。
分析:我們可以延用例1的思路,我們的努力方向不是讓VLOOKUP本身實現多條件查找,而是想辦法重構一個數組。多個條件我們可以用&連接在一起,同樣兩列我們也可以連接成一列數據,然后用IF函數進行組合。
公式:{=VLOOKUP(A9&B9,IF({1,0},A2:A5&B2:B5,C2:C5),2,0)}
公式剖析:
1、A9&B9 把兩個條件連接在一起。把他們做為一個整體進行查找。
2、A2:A5&B2:B5,和條件連接相對應,把部分和姓名列也連接在一起,作為一個待查找的整體。
3、IF({1,0},A2:A5&B2:B5,C2:C5) 用IF({1,0}把連接后的兩列與C列數據合并成一個兩列的內存數組。按F9后可以查看的結果為:
{"銷售張一",1;"銷售趙三",5;"人事楊五",3;"銷售趙三",6}
4、完成了數組的重構后,接下來就是VLOOKUP的基本查找功能了,另外公式中含有多個數據與多個數據運算(A2:A5&B2:B5),,所以必須以數組形式輸入,即按ctrl+shift后按ENTER結束輸入。
三、VLOOKUP函數的批量查找。
VLOOKUP一般情況下只能查找一個,那么多項該怎么查找呢?
例3 要求把如圖表中所有張一的消費金額全列出來
分析:經過前面的學習,我們也有這樣一個思路,我們在實現復雜的查找時,努力的方向是怎么重構一個查找內容和查找的區域。要想實現多項查找,我們可以對查找的內容進行編號,第一個出現的是后面連接1,第二個出現的連接2。。。
公式:{=VLOOKUP(B$9&ROW(A1),IF({1,0},$B$2:$B$6&COUNTIF(INDIRECT("b2:b"&ROW($2:$6)),B$9),$C$2:$C$6),2,)}
公式剖析:
1、B$9&ROW(A1) 連接序號,公式向下復制時會變成B$9連接1,2,3
2、給所有的張一進行編號。要想生成編號,就需要生成一個不斷擴充的區域(INDIRECT("b2:b"&ROW($2:$6)),然后在這個逐行擴充的區域內統計“張一”的個數,在連接上$B$2:$B$6后就可以對所有的張一進行編號了。
3、IF({1,0}把編號后的B列和C組重構成一個兩列數組
通過以上的講解,我們需要知道,VLOOKUP函數的基本用法是固定的,要實現高級查找,就需要借助其他函數來重構查找內容和查找數組。
至此VLOOKUP函數從入門到高級的四篇VLOOKUP函數使用教程全部結束了,VLOOKUP函數在數組運算中還有著其他應用,但只是配角了,所以本系列不再介紹。由于筆者水平有限,不免有錯漏之處,請大家多多指點。
OLE DB 提供程序 'MSDAORA' 報錯。
[OLE/DB provider returned message: 未找到 Oracle 客戶端和網絡組件。這些組件是由 Oracle 公司提供的,是 Oracle 8i 版 (或更高) 客戶軟件安裝的一部分。
在安裝這些組件之前,將無法使用此提供程序。]
OLE DB 錯誤跟蹤[OLE/DB Provider 'MSDAORA' IDBInitialize::Initialize returned 0x80004005: ]
Oracle Client | Microsoft Windows NT、 Oracle Microsoft Windows 95、 Client Windows 98 和 Windows 98 SE |
Microsoft Windows 2000/XP/2003 |
7.x | [HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\TransactionServer\Local Computer\My Computer] "OracleXaLib"="xa73.dll" "OracleSqlLib"="SQLLib18.dll" "OracleOciLib"="ociw32.dll
|
[HKEY_LOCAL_MACHINE\SOFTWARE Microsoft\MSDTC\MTxOCI] "OracleXaLib"="xa73.dll" "OracleSqlLib"="SQLLib18.dll" "OracleOciLib"="ociw32.dll" |
8.0 | [HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\Transaction Server \Local Computer\My Computer] "OracleXaLib"="xa80.dll" "OracleSqlLib"="sqllib80.dll" "OracleOciLib"="oci.dll" |
[HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\MSDTC\MTxOCI] "OracleXaLib"="xa80.dll" "OracleSqlLib"="sqllib80.dll" "OracleOciLib"="oci.dll" |
8.1 | [HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\Transaction Server \Local Computer\My Computer] "OracleXaLib"="oraclient8.dll" "OracleSqlLib"="orasql8.dll" "OracleOciLib"="oci.dll" |
[HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\MSDTC\MTxOCI] "OracleXaLib"="oraclient8.dll" "OracleSqlLib"="orasql8.dll" "OracleOciLib"="oci.dll" |
9.0 | [HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\Transaction Server \Local Computer\My Computer] "OracleXaLib"="oraclient9.dll" "OracleSqlLib"="orasql9.dll" "OracleOciLib"="oci.dll" |
[HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\MSDTC\MTxOCI] "OracleXaLib"="oraclient9.dll" "OracleSqlLib"="orasql9.dll" "OracleOciLib"="oci.dll" |
10.0 | [HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\Transaction Server \Local Computer\My Computer] "OracleXaLib"="oraclient10.dll" "OracleSqlLib"="orasql10.dll" "OracleOciLib"="oci.dll" |
[HKEY_LOCAL_MACHINE\SOFTWARE \Microsoft\MSDTC\MTxOCI] "OracleXaLib"="oraclient10.dll" "OracleSqlLib"="orasql10.dll" "OracleOciLib"="oci.dll" |
優先級 | 運算符 | 結合性 |
1 | () [] . | 從左到右 |
2 | ! +(正) -(負) ~ ++ -- | 從右向左 |
3 | * / % | 從左向右 |
4 | +(加) -(減) | 從左向右 |
5 | << >> >>> | 從左向右 |
6 | < <= > >= instanceof | 從左向右 |
7 | == != | 從左向右 |
8 | &(按位與) | 從左向右 |
9 | ^ | 從左向右 |
10 | | | 從左向右 |
11 | && | 從左向右 |
12 | || | 從左向右 |
13 | ?: | 從右向左 |
14 | = += -= *= /= %= &= |= ^= ~= <<= >>= >>>= | 從右向左 |
jQuery UI里面只有一個DatePicker,只能選擇日期,不能選擇時間,有人做了一個可以選擇時間的DateTimePicker,在這里(http://razum.si/jQuery-calendar/TimeCalendar.html)可以看到,把jquery.js,jquery-calendar.js,jquery-calendar.css下回來之后就可以用了。
但是有幾個Bug需要自己修改:
1、當輸入框里面的時間是0點時,控件顯示不完整,這是因為有個函數有bug,如下所示:
????????
while
?(value.charAt(
0
)?
==
?'
0
'?
)?{
????????????value?
=
?value.substring(
1
);
????????}
這一句,如果是0點的話,最終會出錯,因為它的長度最后是1,不能執行substring(1),改成下面就好了:
初次使用jQuery,發現真是個好東西,把很多東西都簡化了,循環基本上都去掉了,可以說是開創了JS的一種新模式,雖然開始覺得有點不習慣,但是很容易學習也很容易看懂。一個神奇的$原來有那么多的功能,很強大,呵呵。
最讓人欣慰的是它屏蔽了所有瀏覽器的差別,可以在各種瀏覽器上用相同的代碼實現相同的效果。
二維條形碼比普通的條形碼能保存更多的信息,已經應用到很多領域里面。例如手機電影票,就是一個嵌在彩信里面的二維碼圖像。南航也推出了網上辦理登機牌業務,辦理完成之后往手機發送一條包含二維碼的彩信,到了機場就可以通過自助設備掃描二維碼,打印登機牌。
然而,專業的二維碼掃描設備價格十分昂貴,最便宜的都在1000元以上,到淘寶上搜搜就知道了。借助Java和一個開源的庫,我們卻可以通過普通的網絡攝像頭實現相同的效果,成本只需要幾十塊。
Open Source QR Code Library是一個開源的QR Code(二維條形碼的一種)生成和讀取的庫,官方網站為:http://qrcode.sourceforge.jp/,里面包含了生成和讀取QR Code的所有代碼,其中有個jmfexample就能實現通過攝像頭讀取QR Code,經過本人嘗試,幾十塊的普通攝像頭效果已經不錯了,一次讀取幾百字節都沒問題。
使用這個庫的步驟如下:
1、到其官方網站下載回來;
2、到sun的網站下載JMF包并安裝;
3、插上攝像頭,打開我的電腦,查看是否出現“USB視頻設備”,然后打開,看攝像頭工作是否正常
4、運行JMF里面的JMF Registry程序,點擊“Detect Capture Devices”,查找視頻設備,查找到之后會在左邊的列表里出現“vfw:Microsoft WDM Image Capture (Win32):0”類似的設備,點擊就會在右邊出現其詳細信息,我的攝像頭是這樣的:
Name = vfw:Microsoft WDM Image Capture (Win32):0
Locator = vfw://0
Output Formats---->
0. javax.media.format.YUVFormat
? YUV Video Format: Size = java.awt.Dimension[width=640,height=480] MaxDataLength = 614400 DataType = class [B yuvType = 32 StrideY = 1280 StrideUV = 1280 OffsetY = 0 OffsetU = 1 OffsetV = 3
1. javax.media.format.YUVFormat
? YUV Video Format: Size = java.awt.Dimension[width=160,height=120] MaxDataLength = 38400 DataType = class [B yuvType = 32 StrideY = 320 StrideUV = 320 OffsetY = 0 OffsetU = 1 OffsetV = 3
2. javax.media.format.YUVFormat
? YUV Video Format: Size = java.awt.Dimension[width=176,height=144] MaxDataLength = 50688 DataType = class [B yuvType = 32 StrideY = 352 StrideUV = 352 OffsetY = 0 OffsetU = 1 OffsetV = 3
3. javax.media.format.YUVFormat
? YUV Video Format: Size = java.awt.Dimension[width=320,height=240] MaxDataLength = 153600 DataType = class [B yuvType = 32 StrideY = 640 StrideUV = 640 OffsetY = 0 OffsetU = 1 OffsetV = 3
4. javax.media.format.YUVFormat
? YUV Video Format: Size = java.awt.Dimension[width=352,height=288] MaxDataLength = 202752 DataType = class [B yuvType = 32 StrideY = 704 StrideUV = 704 OffsetY = 0 OffsetU = 1 OffsetV = 3
注意,其中Output Formats都是javax.media.format.YUVFormat,而QR Code Library里默認的設備不是這種格式的,所以需要對源碼作一定的修改。
5、用Eclipse打開QR Code Library的源碼,作出一些適當的修改:
如果攝像頭是上面所說的只支持YUV格式,則需要修改jp.sourceforge.qrcode.example.jmf.camDataSource.java,把setMainSource函數里的
VideoFormat vidformat = new VideoFormat(VideoFormat.RGB);
修改為
VideoFormat vidformat = new VideoFormat(VideoFormat.YUV);
否則永遠也找不到攝像頭。
6、把JMF包里的jmf.jar放到Classpath里
7、執行jp.sourceforge.qrcode.example.jmf.jmfexample,搞定
當然,由于源碼開放的,只要符合許可,你想怎么改都行,可以把它嵌入到某個應用程序里面,這個程序就具有了掃描QR Code的功能了。
為了充分利用晚上的帶寬,我搞了一部專門的破機用于BT/EMULE下載,上班時間為了不影響大家上網,必須停止下載任務。有的下載工具本身帶有計劃任務功能,但是有些只能控制速度,不能控制連接,例如eMule,雖然可以停止下載,但是連接還是很多的,脆弱的ADSL路由/Modem經不起大量的連接,很容易就死翹翹了。這種情況下,最痛快的解決辦法是拔線,但是每天插拔也不是辦法,軟一點的辦法是禁用網卡,但是每次手動操作也不是辦法。更直接的辦法就是計劃任務自動啟用/禁用網卡了。要實現這種目的必須要有能夠自動運行的工具,devcon就是一個命令行工具,能夠在命令行中實現“設備管理器”的功能,我這里只要“啟用/禁用”功能即可。
devcon的下載地址:
http://support.microsoft.com/kb/311272/zh-cn
微軟出品,權威產品。
使用的時候還是有點小問題,搜索了一下找不到答案,只有自己解決了:
1、禁用設備的命令是:
devcon disable 設備ID
這個設備ID怎么得到呢?通過設備管理器,在設備上點擊“屬性”,在“詳細信息”標簽里面有個下拉列表,選擇“設備范例Id”,下面顯示出來的就是設備ID,
怎么把這個ID復制出來呢?右鍵是沒辦法的,但是直接CTRL+C就OK了。
2、設備ID不能直接輸入,否則會把ID開頭相同的一大堆設備都操作一遍,最后還會出幾個錯誤提示;加上雙引號也不行,會提示沒有設備被禁用/啟用;必須這樣寫:@"設備ID",所以最后的命令格式是:
devcon disable @"設備ID"
不知道是什么道理。
在計劃任務里面添加兩個任務:“啟用網卡”,“禁用網卡”,分別用devcon enable,devcon disable命令即可,例如早上8點半禁用,晚上23:30啟用(有部分好筒子晚上加班)。這樣一來,就可以24小時開著那幾個下載程序也不會有影響了,在網卡禁用的時候,無論它們怎么嘗試連接,都跳不出如來佛的掌心。
CPU | Phenom X4 9550 盒裝 | 1120 |
主板 | 技嘉GA-MA78G-DS3H | 680 |
內存 | Kingston DDR2-800 1G*2 | 140*2=280 |
硬盤 | 希捷7200.11 500GB | 585 |
光驅 | BenQ DW2000 DVD刻錄機 | 225 |
機箱 | 航嘉時光之門H301 | 265 |
電源 | TT KK500P (KK500A的升級版) | 470 |
顯示器 | 三星 2243BW | 1850 |
鍵盤鼠標 | 雜牌套裝 | 30 |
合計 | 5505 |
申請者 | 審批者 | 執行者 | |
未回復列表 | 自己已發出但未被執行者執行的列表 | 申請者已提交但自己未審批的列表 | 審批已通過但自己未執行的列表 |
已回復列表 | 自己已發出且執行者已執行的列表 | 申請者已提交且自己已審批的列表 | 審批已通過且自己已執行的列表 |