2018年7月18日 星期三

Java 一些應用 [ csv reader / array of class / for( : ) ]

分享一些工作上用到的寫法 ( java )


  1.  csv reader 
  2. array of class
  3. for (:) 

因為工作上需要讀取csv檔案的需求 , java 本身有提供一些 method 
首先要 import opencsv-3.8.jar 檔案(我當時是3.8版本的)

讀取檔案路徑:                                                                                                              
                m_csvFile=""; //file path                                                                                
                                                                                                                        
//Chose CSV File                                                                                            
JFileChooser fileChooser = new JFileChooser();                                           
int returnValue = fileChooser.showOpenDialog(null);                                    
if (returnValue == JFileChooser.APPROVE_OPTION){                                
File selectedFile = fileChooser.getSelectedFile();                                   
m_csvFile = selectedFile.getPath();                                                         
}else{                                                                                                               
// error handle...                                                                                       
}                                                                                                                       
return true;                                                                                                       
接著呼叫 CSVReader 物件:                                                                                           
                reader = new CSVReader(new FileReader(m_csvFile));                               
                                                                                                                                        
                // Reading All Records at once into a List<String[]>                                     
        List<String[]> records= reader.readAll(); //讀取csv資料到list裡面             
        reader.close();                                                                                                   
                // records.size() 就是讀取到 csv 所有筆數                                                    
        SpcData spcAry[] = new SpcData[records.size()];  //宣告 array of class       
                                                                                                                                         
for ( string[] csvRecord : records ) 的用法: records 陣列中,從第一個值取到最後一個值 
         for (String[] csvRecord records) {                                                                       
        spcAry[count] = new SpcData();                                                            
        spcAry[count].sht_id csvRecord [0];                                                     
        spcAry[count].mes_id csvRecord [1];                                                     
        spcAry[count].data_id csvRecord [2];                                                     
        spcAry[count].data_group= csvRecord [3];                                                   
        spcAry[count].data_attr = csvRecord [4];                                                      
        spcAry[count].u_spec csvRecord [5];                                                     
           spcAry[count].l_spec csvRecord [6];                                                     
        spcAry[count].data_value= csvRecord [7];                                                   
        count++;                                                                                                 
        }                                                                                                                       
                                                                                                                                 
SpcData 的 Class:                  
          private class SpcData { 
String sht_id;          
String mes_id;        
String data_id;       
String data_group; 
String data_attr;     
String l_spec;         
String u_spec;        
String data_value;  
}                                     

CSV Reader 參考網頁: https://www.callicoder.com/java-read-write-csv-file-opencs

2018年7月13日 星期五

利用excel 組 Oracle 語法

PMS_CHKLABEL

資料:

語法:


利用 excel 函數 (有日期格式)

=CONCATENATE("INSERT INTO PMS_CHKLABEL VALUES('",A2,"','",B2,"',TO_DATE('" & C2 & "', 'yyyy-mm-dd'),'",D2,"','",E2,"');")


PMS_CHK_ITEM

資料:


語法:





利用 excel 函數 (有日期格式)
=CONCATENATE("INSERT INTO PMS_CHKITEM VALUES('",A8,"','",B8,"','",C8,"','",D8,"','",E8,"','",F8,"');")



2018年7月5日 星期四

Oracle REGEXP_SUBSTR 用法

REGEXP_SUBSTR 寫法如下: 

REGEXP_SUBSTRDATA_GROUP , '   [ ^ _ ]   { 7 }  '  )
DATA_GROUP  : 欄位
 [ ^ _ ]       : 中括號裡面,^後的字元 = 停止字元,這表示(遇到 底線 就停止)
{ 7 }          : 取 7 個字元 
{ m }         : 取 m 個字元
{ m , }       : 最少取 m 個字元
{ m ,  n}    : 最少取 m 個字元 , 最多取 n 個字元


假設今天我們資料長這樣 ,
我們要擷取DATA_ATTR是"C"  的條件中
EQU_Mooney 其中的 Mooney 當作之後對應的數值
EQU_gravity(BC) gravity(BC) 
= > 簡單來說就是取底線之後字串


如此就有我們想要的結果了



2018.07.05 備註: 
單獨使用 REGEXP_SUBSTR 抓字串顯示的話 , 是不會有什麼問題
如果要再把 REGEXP_SUBSTR 抓出來的字串做額外判斷 ex: like 
要注意後面他會補空白哦
因此要使用 TRIM 函數把空白清掉

情境如下: 
原本 TABLE 資料表










使用者只想要 DATA_ATTR為 "F" 的資料 , 並且要多機台欄位
而他的機台就是要去抓 DATA_ATTR為 "C" 去補

使用者想要呈現的樣子
語法如下 
ORACLE 要利用 | | 連接 字串 , TRIM 要去掉空白

結果



2018年6月27日 星期三

2018年6月22日 星期五

notepad ++ 喜歡的配色


Notepad ++ 喜歡的配色 , 以cpp為例子

方法一: 懶人方法

(1) 設定 -> 設定程式語言格式 -> 主題選取(選擇 Monokai) 
(2) 在安裝目錄資料夾底下   %APPDATA%\Notepad++   打開 stylers.model.xml
(3) 開啟 stylers.model.xml 尋找 c ++ 關鍵字
(4) 把這些覆蓋過去

<LexerType name="cpp" desc="C++" ext="">
            <WordsStyle name="PREPROCESSOR" styleID="9" fgColor="804000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="DEFAULT" styleID="11" fgColor="000000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="INSTRUCTION WORD" styleID="5" fgColor="0000FF" bgColor="FFFFFF" fontName="" fontStyle="1" fontSize="" keywordClass="instre1" />
            <WordsStyle name="TYPE WORD" styleID="16" fgColor="8000FF" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" keywordClass="type1" />
            <WordsStyle name="NUMBER" styleID="4" fgColor="FF8000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="STRING" styleID="6" fgColor="808080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="CHARACTER" styleID="7" fgColor="808080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="OPERATOR" styleID="10" fgColor="000080" bgColor="FFFFFF" fontName="" fontStyle="1" fontSize="" />
            <WordsStyle name="VERBATIM" styleID="13" fgColor="000000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="REGEX" styleID="14" fgColor="000000" bgColor="FFFFFF" fontName="" fontStyle="1" fontSize="" />
            <WordsStyle name="COMMENT" styleID="1" fgColor="008000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="COMMENT LINE" styleID="2" fgColor="008000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="COMMENT DOC" styleID="3" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="COMMENT LINE DOC" styleID="15" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="COMMENT DOC KEYWORD" styleID="17" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="1" fontSize="" />
            <WordsStyle name="COMMENT DOC KEYWORD ERROR" styleID="18" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="PREPROCESSOR COMMENT" styleID="23" fgColor="008000" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
            <WordsStyle name="PREPROCESSOR COMMENT DOC" styleID="24" fgColor="008080" bgColor="FFFFFF" fontName="" fontStyle="0" fontSize="" />
        </LexerType>

方法二:

(1) 設定 -> 設定程式語言格式 -> 主題選取(選擇 Monokai) 
(2) 左邊程式語言選擇 C++
(3) 樣式部分:
                        INSTRUCTION WORD: 字色修改成藍色(色調,濃度,亮度) = (140,240,142)
                        TYPE WORD: 字色修改成藍色(140,240,142)
                        NUMBER: 字色修改成藍色(140,240,142)
                        OPERATOR: 字色修改橘色(13,240,150)


2018年6月19日 星期二

移除討人厭的 dll 檔案

以下範例為 Notepad ++ 的 NppShell.dll 刪不掉

刪除指令如下:

(1) 先進到 Notepad ++ 目錄底下
(2) tasklist /m NppShell_06.dll
(3) 可以看到哪個 .exe 占用 NppShell_06.dll
(4) 發現 explorer.exe 檔案 ( 不能亂關 ) , 所以我們要下指令
(5) taskkill /f /PID 3268  (註: 3268是我畫面上的 PID)
(6) 此時桌面消失 , 不用緊張
(7) 重啟 explorer.exe 即可



2018年6月15日 星期五

C 語言 Strtok 用法與原理

程式碼:


















一開始的變數:







(1)   執行完 p = strtok(mailList, delim); , Strtok 會把 ; 的地方塞入 ‘\0’
可以把 mailList 想像成 hsiwei@kenda.com.tw \0 alexsie@kenda.com.tw
因為mailLisr 被填入\0
所以值那邊只會抓到 hsiwei@kenda.com.tw 但其實後面還有alexsie@kenda,com,tw
然後指標 p 會指向mailList的這塊記憶體位置

如下圖


(2) 因為p!=NULL 所以進入到 while迴圈, 接著執行 p = strtok(NULL, delim);
由於 ‘\0’就是 NULL , 所以指標pNULL開始往後找, 找到下一個 ; 為止

執行完後變數如下圖


用圖片來說明

2018年5月28日 星期一

[ ORACLE ] 顯示某Table 所有欄位語法

參考網站:
https://stackoverflow.com/questions/452464/how-can-i-get-column-names-from-a-table-in-oracle


記得 table_name 要大寫, ORACLE 很在意大小寫的 😃

SELECT table_name, column_name, data_type, data_length
FROM USER_TAB_COLUMNS
WHERE table_name = 'MYTABLE'
ORDER BY column_id

2018年5月25日 星期五

oracle insert into ( columns : timestamp )

insert into test values ( TO_TIMESTAMP('2018-05-25 18:18:18.333', 'YYYY-MM-DD HH24:MI:SS.FF') )

2018年5月17日 星期四

抓取Log關鍵字的好用軟體 - UnixLike

此範例是在遠端桌面Server(Q:\)裏頭的log
關鍵字是: "UPDATE PPT1D.AEQPTRESV SET LOT_ID='U111805160014'"


抓關鍵字語法:
grep + 要找的關鍵字  + Log存放路徑 + > 要寫到哪個路徑.檔案裡

grep "UPDATE PPT1D.AEQPTRESV SET LOT_ID='U111805160014'" Q:\prod\stdv14_ora_msmq\mes\aplog\kap02\*_2018-05-17*.log > c:\test.txt





2018年5月10日 星期四

Oracle In 多重欄位作法

如果遇到有多個欄位,要做查詢
一般來說我們的直覺會是這樣下

SELECT * FROM AEQPTRESV WHERE 1=1 AND (LOT_ID = 'U101804270010' AND NX_OPE_NO='090010')OR    (LOT_ID = 'U101804270009' AND NX_OPE_NO='090010')OR    (LOT_ID = 'U101804270007' AND NX_OPE_NO='090010').........

但是這種作法太耗費效能了, 於是突發奇想是否可以這樣抓

SELECT * FROM AEQPTRESV 
WHERE 1=1 
AND (LOT_ID , NX_OPE_NO) 
IN (
           ('U101804270010','090010'),
           ('U101804270009','090010'),
           ('U101804270007','090010')
)

後來發現竟然可以 😃😃😃
語法改成這樣下,不但畫面比較好看,效能也會比較好哦!!!

Java 一些應用 [ csv reader / array of class / for( : ) ]

分享一些工作上用到的寫法 ( java )  csv reader  array of class for (:)  因為工作上需要讀取csv檔案的需求 , java 本身有提供一些 method  首先要 import opencsv-3.8.jar ...