2016年12月24日 星期六

永久修改 Ipython Nortebook 或 Jupter Notebook 的默認目錄

參考:
http://xuanchao1980.com/2016/05/12/jupyterDirectory/

步驟:
Ipython Notebook

1.打開命令行(初始化配置文件):
  1. ipython profile create

這個命令,會初始化一份配置文件ipython_notebook_config.py,輸入後找到下面這行

# c.NotebookManager.notebook_dir = u'D:\\love\\cat'

如果没有,請找這行:

# c.NotebookApp.notebook_dir = u'Z:\\luv\\cat'

2.去掉註解&空格,修改路徑路徑為自己想要的

Jupyter Notebook

1.打開命令行(初始化配置文件):
  1. jupyter notebook --generate-config
這個命令,會初始化一份配置文件.jupyter\jupyter_notebook_config.py
輸入後找到下面這行

# c.NotebookApp.notebook_dir = u'D:\\love\\you'


2.去掉註解&空格,修改路徑路徑為自己想要的

2016年12月20日 星期二

Word Cloud 文字雲 - jQCloud & WordCloud2

Sample Step:

1.Download word cloud jquery:
http://mistic100.github.io/jQCloud/#usage



2.Include package & jQuery CDN
- jqcloud.min.js- jqcloud.min.css
- jqcloud.min.js- jqcloud.min.js
- https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js

- 程式碼
  1. <head>
  2. <meta charset="utf-8">
  3. <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"> </script>
  4. <script src="jqcloud.min.js"></script>
  5. <link rel="stylesheet" href="jqcloud.min.css">
  6. <title>test</title>
  7. </head>

3.設定『資料』 & 啟用文字雲
- 要記得給文字雲『範圍大小』,否則畫面上看不到
  1. $('#keywords').jQCloud(words, {
  2. width: 500,
  3. height: 350
  4. });

- 設定假資料
  1. <script>
  2. $(function(){
  3. var words = [
  4. {text: "Lorem", weight: 13},
  5. {text: "Ipsum", weight: 10.5},
  6. {text: "Dolor", weight: 9.4},
  7. {text: "Sit", weight: 8},
  8. {text: "Amet", weight: 6.2},
  9. {text: "Consectetur", weight: 5},
  10. {text: "Adipiscing", weight: 5},
  11. ];
  12.  
  13. <!-- $('#demo').jQCloud(words); -->
  14. $('#demo').jQCloud(words, {
  15. width: 600,
  16. height: 600
  17. });
  18. });
  19. </script>

4.Result



5.Sample code
  1. <!doctype html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"> </script>
  6. <script src="jqcloud.min.js"></script>
  7. <link rel="stylesheet" href="jqcloud.min.css">
  8. <title>test</title>
  9. </head>
  10. <script>
  11. $(function(){
  12. var words = [
  13. {text: "Lorem", weight: 13},
  14. {text: "Ipsum", weight: 10.5},
  15. {text: "Dolor", weight: 9.4},
  16. {text: "Sit", weight: 8},
  17. {text: "Amet", weight: 6.2},
  18. {text: "Consectetur", weight: 5},
  19. {text: "Adipiscing", weight: 5},
  20. ];
  21.  
  22. <!-- $('#demo').jQCloud(words); -->
  23. $('#demo').jQCloud(words, {
  24. width: 600,
  25. height: 600
  26. });
  27. });
  28.  
  29. </script>
  30. <body>
  31. <div id="demo" style="border:thin solid black">
  32. </div>
  33. </body>
  34.  
  35. </html>

6.Advance Skill 
[自訂設定]
- delay: 50 (字體顯示的速度)
- steps : Number of "steps" to map the words on, depending on their weight (大約會有幾種字體大小,會與自設的color進行比對)
- colors: 自訂顏色
-from-to: 字體最大-最小(根據container的大小)
  1. $('#wordCloud').jQCloud(words, {
  2. delay: 50,
  3. width: 500,
  4. height: 500,
  5. autoResize: true,
  6. steps : 50,
  7. //最凸顯
  8. colors: ["#CC0066", "#CC0066", "#009999", "#009999", "#FFCC33", "#FFCC33", "#0099CC", "#0099CC", "#FF6666","#FF6666",
  9. "#FF33CC", "#FF33CC", "#FF6600", "#FF6600", "#009966", "#009966", "#CC6633", "#CC6633", "#FF6666","#FF6666",
  10. "#555555", "#555555", "#555555", "#555555", "#555555", "#444444", "#444444", "#444444", "#444444","#444444",
  11. "#666633", "#666633", "#666633", "#666633", "#666699", "#666666", "#666666", "#666666", "#666666","#666666",
  12. "#333333", "#333333", "#333333", "#333333", "#333333", "#999999", "#999999", "#999999", "#999999","#999999"
  13. ],
  14. fontSize: {
  15. from: 0.08,
  16. to: 0.02
  17. }
  18. });

[文字雲特殊效果(字體隨滑鼠移出移入改變)]
  1. //文字雲特殊效果
  2. $(document).on('mouseenter','.jqcloud-word',function(){
  3. var font_size = parseFloat($(this).css("font-size"));
  4. var newSize = font_size + 10;
  5. $(this).css("font-size",newSize + 'px');
  6. }).on('mouseout','.jqcloud-word',function(){
  7. var font_size = parseFloat($(this).css("font-size"));
  8. var newSize = font_size - 10;
  9. $(this).css("font-size",newSize + 'px');
  10. });

[使用者可調整"字體顏色"、文字雲型狀]

1.按下"更新"
2.刪掉文字雲
3.重建文字雲
  1. //delete
  2. wordCloud.jQCloud('destroy');
  3. //update word cloud
  4. wordCloud.jQCloud(words, {
  5. delay: 40,
  6. width: width,
  7. height: height,
  8. autoResize: true,
  9. steps : 50,
  10. colors: colorStyle,
  11. shape: shape,
  12. fontSize: {
  13. from: 0.08,
  14. to: 0.02
  15. }
  16. });

4.sample code
  1. //文字雲update
  2. $('#updateButton').on('click', function() {
  3. var wordCloud = $('#wordCloud');
  4. var selectColorStyle = $('#colorStyle').val();
  5. var selectShape = $('#shape').val();
  6. var colorStyle;
  7. //custom color style
  8. if (selectColorStyle == '1') {
  9. colorStyle = ["#CC0066", "#CC0066", "#009999", "#009999", "#FFCC33", "#FFCC33", "#0099CC", "#0099CC", "#FF6666","#FF6666",
  10. "#FF33CC", "#FF33CC", "#FF6600", "#FF6600", "#009966", "#009966", "#CC6633", "#CC6633", "#FF6666","#FF6666",
  11. "#555555", "#555555", "#555555", "#555555", "#555555", "#444444", "#444444", "#444444", "#444444","#444444",
  12. "#666633", "#666633", "#666633", "#666633", "#666699", "#666666", "#666666", "#666666", "#666666","#666666",
  13. "#333333", "#333333", "#333333", "#333333", "#333333", "#999999", "#999999", "#999999", "#999999","#999999"
  14. ];
  15. } else if (selectColorStyle == '2') {
  16. colorStyle = ["#CC0066", "#CC0066", "#009999", "#009999", "#FFCC33", "#FFCC33", "#0099CC", "#0099CC", "#FF6666","#FF6666",
  17. "#FF33CC", "#FF33CC", "#FF6600", "#FF6600", "#009966", "#009966", "#CC6633", "#CC6633", "#FF6666","#FF6666",
  18. "#3399CC", "#3399CC", "#CC6600", "#CC6600", "#999999", "#444444", "#444444", "#444444", "#444444","#444444",
  19. "#666633", "#666633", "#666633", "#666633", "#666699", "#666666", "#666666", "#666666", "#666666","#666666",
  20. "#333333", "#333333", "#333333", "#333333", "#333333", "#999999", "#999999", "#999999", "#999999","#999999"
  21. ];
  22. } else if (selectColorStyle == '3') {
  23. colorStyle = ["#CC0066", "#CC0066", "#009999", "#009999", "#FFCC33", "#FFCC33", "#0099CC", "#0099CC", "#FF6666","#FF6666",
  24. "#FF33CC", "#FF33CC", "#FF6600", "#FF6600", "#009966", "#009966", "#CC6633", "#CC6633", "#FF6666","#FF6666",
  25. "#3399CC", "#3399CC", "#CC6600", "#CC6600", "#999999", "#999999", "#CCCC33", "#CCCC33", "#CCCC33","#CCCC33",
  26. "#FF9933", "#FF9933", "#CC9999", "#CC9999", "#666699", "#666699", "#FF9900", "#FF9900", "#0099CC","#0099CC",
  27. "#CCCC99", "#CCCC99", "#FF6666", "#FF6666", "#FFCC99", "#FFCC99", "#CC3399", "#CC3399", "#99CC33","#99CC33"
  28. ];
  29. }
  30. //custom shape
  31. var width;
  32. var height;
  33. var shape;
  34. if (selectShape == '1') {
  35. width = 550;
  36. height = 400;
  37. shape = 'elliptic';
  38. } else if (selectShape == '2') {
  39. width = 500;
  40. height = 500;
  41. shape = 'elliptic';
  42. } else {
  43. width = 550;
  44. height = 400;
  45. shape = 'rectangular';
  46. }
  47. //delete
  48. wordCloud.jQCloud('destroy');
  49. //update word cloud
  50. wordCloud.jQCloud(words, {
  51. delay: 40,
  52. width: width,
  53. height: height,
  54. autoResize: true,
  55. steps : 50,
  56. colors: colorStyle,
  57. shape: shape,
  58. fontSize: {
  59. from: 0.08,
  60. to: 0.02
  61. }
  62. });
  63. });

Word Cloud 2

1.下載:
https://timdream.org/wordcloud2.js/#red-chamber

2.Sample Code:
  1. <!doctype html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"> </script>
  6. <script src="wordcloud2.js"></script>
  7. <title>test</title>
  8. </head>
  9. <script>
  10. $(function(){
  11. var words = [
  12. ["哈哈哈哈",60],
  13. ["Ipsum",19],
  14. ["Dolor",18],
  15. ["Sit",17],
  16. ["Amet",16],
  17. ["Consectetur",15],
  18. ["Adipiscing",14],
  19. ["dsfsf",13],
  20. ["Ipsdfsum",12],
  21. ["Dosdfsdflor",11],
  22. ["台灣",10],
  23. ["Ipsum",9],
  24. ["Dolor",8],
  25. ["Sit",7],
  26. ["Amet",6],
  27. ["Consectetur",5],
  28. ["Adipiscing",4],
  29. ["dsfsf",3],
  30. ["Ipsdfsum",2],
  31. ["Dosdfsdflor",1],
  32. ["台灣",25],
  33. ["Ipsum",24],
  34. ["Dolor",23],
  35. ["Sit",22],
  36. ["Amet",21],
  37. ];
  38.  
  39. WordCloud($('#wordCloud')[0], {
  40. list: words,
  41. classes: 'wordCloud',
  42. wait: 30,
  43. gridSize: 10,
  44. weightFactor: 1.6,
  45. fontFamily: 'Hiragino Mincho Pro, serif',
  46. color: 'random-dark',
  47. backgroundColor: '#FFFFFF',
  48. rotateRatio: 0
  49. });
  50. //文字雲update
  51. $('#updateButton').on('click', function() {
  52. //custom shape
  53. var selectShape = $('#shape').val();
  54. var shape;
  55. if (selectShape == '1') {
  56. shape = 'circle';
  57. } else if (selectShape == '2') {
  58. shape = 'star';
  59. } else if (selectShape == '3') {
  60. shape = 'pentagon';
  61. } else if (selectShape == '4'){
  62. shape = 'diamond';
  63. } else if (selectShape == '5') {
  64. shape = 'triangle';
  65. }
  66. WordCloud($('#wordCloud')[0], {
  67. list: words,
  68. classes: 'wordCloud',
  69. wait: 30,
  70. shape: shape,
  71. gridSize: 10,
  72. weightFactor: 1.6,
  73. fontFamily: 'Hiragino Mincho Pro, serif',
  74. color: 'random-dark',
  75. backgroundColor: '#FFFFFF',
  76. rotateRatio: 0
  77. });
  78. });
  79. //文字雲特殊效果
  80. $(document).on('mouseenter','.wordCloud',function(){
  81. var font_size = parseFloat($(this).css("font-size"));
  82. var newSize = font_size + 10;
  83. $(this).css("font-size",newSize + 'px');
  84. }).on('mouseout','.wordCloud',function(){
  85. var font_size = parseFloat($(this).css("font-size"));
  86. var newSize = font_size - 10;
  87. $(this).css("font-size",newSize + 'px');
  88. });
  89. });
  90. </script>
  91. <body>
  92. <div style="border:thin solid red;align:center">
  93. <div id="wordCloud" style="width:500px;height:500px;border:thin solid black;margin:0 auto">
  94. </div>
  95. </div>
  96. <select id="shape" class="pull-right" style="height: 27px;width: 100px;margin: 3px" type="select">
  97. <option value='1' selected="selected">雲朵</option>
  98. <option value='2' >星星</option>
  99. <option value='3'>五角大廈</option>
  100. <option value='4'>鑽石</option>
  101. <option value='5'>金字塔</option>
  102. </select>
  103. </body>
  104. <button class="" id="updateButton">Update</button>
  105.  
  106. </html>

2016年12月19日 星期一

Hibernate Criteria - DQL

Hibernate - Criteria

參考:
http://openhome.cc/Gossip/HibernateGossip/CriteriaBasic.html

範例:
1.add()
- org.hibernate.criterion.Criteria 實例代表著一個條件,您要使用org.hibernate.Criteria的add()方法加入這些條件實例,例如查詢” age”大於20且小於40的資料

- 使用add()時,預設是使用and來組合條件

- gt()大於 lt小於
  1. Criteria criteria = session.createCriteria(User.class);
  2. criteria.add(Restrictions.gt("age", new Integer(20)));
  3. criteria.add(Restrictions.lt("age", new Integer(40)));
  4. List users = criteria.list();

2.or()
- age等於(eq)20或(or)age為空(isNull)的條件
  1. Criteria criteria = session.createCriteria(User.class);
  2. criteria.add(Restrictions.or(
  3. Restrictions.eq("age", new Integer(20)),
  4. Restrictions.isNull("age")
  5. ));
  6. List users = criteria.list();

3.like()
- 查詢"name"中名稱為"just"開頭的資料:
  1. Criteria criteria = session.createCriteria(User.class);
  2. criteria.add(Restrictions.like("name", "just%"));
  3. List users = criteria.list();

4.in()
- 條件要放 『陣列 []
  1. String[] queryArray = {"John", "Ian"}
  2.  
  3. criteria.add(Restrictions.in(columnName, queryArray)); // 使用criteria columnName要放『物件的名稱』not 欄位名稱

5.between()
- 要注意型態問題(ex. timestamp)
  1. Criteria criteria = session.createCriteria(AuditTrail.class);
  2. criteria.add(Restrictions.between("auditDate", sDate, eDate));

6.Restrictions的幾個常用限定查詢方法如下表所示:
方 法說 明
Restrictions.eq等於
Restrictions.allEq使用Map,使用key/value進行多個等於的比對
Restrictions.gt大於 >
Restrictions.ge大於等於 >=
Restrictions.lt小於 <
Restrictions.le小於等於 <=
Restrictions.between對應SQL的BETWEEN子句
Restrictions.like對應SQL的LIKE子句
Restrictions.in對應SQL的in子句
Restrictions.andand關係
Restrictions.oror關係
Restrictions.sqlRestrictionSQL限定查詢

2016年12月16日 星期五

Hibernate SQL - DML、DQL、JOIN 範例

SQL
參考:http://blog.csdn.net/vacblog/article/details/7769976

-Select
1.addEntity()
透過『addEntity()』將"table"與"實體類"關聯在一起
這樣可以融合SQL簡潔的語法與Hibernate的方便性

使用addEntity()的大前提
-查詢返回的是某個table的全部數據  
-該table有對應的映射實體

這時候才能透過addEntity()方法將查詢結果轉換成實體
  1. Query query = session.createSQLQuery(
  2. "SELECT * FROM user_account ua WHERE ua.account=:account AND ua.user_email=:emailAddress ")
  3. .addEntity(UserAccountEntity.class) //結合entity的方式把資料傳回來,但使用時有前提
  4. .setParameter("account", account)
  5. .setParameter("emailAddress", emailAddress);
  6. resultList = query.list();

2.使用別名的addEntity()
  1. String sql = "select {myUser.*} from user_information myUser ORDER BY myUser.id";
  2. SQLQuery query = session.createSQLQuery(sql);
  3. query.addEntity("myUser", UserInformationEntity.class);

3.addScalar()
最基本的SQL查询就是取得一個物件的列表:
  1. session.createSQLQuery("select * from person_inf").list();
  2. session.createSQLQuery("select id,name,age from person_inf").list();

此時會返回一個Object陣列组成的List,陣列每個元素都是person_inf表的一個欄位值。Hibernate會使用ResultSetMetadata來判定返回的值的實際順序跟類型。
但是在JDBC中過多的使用ResultSetMetadata會降低程序的性能。為避免過多使用ResultSetMetadata或者指定更加明確的返回值類型,我們可以使用addScalar()方法提高效能
  1. session.createSQLQuery("select * from person_inf")
  2. .addScalar("name",StandardBasicTypes.STRING)
  3. .addScalar("age",StandardBasicTypes.INT)
  4. .list();

上述查询指定了:
-SQL查询欄位。
-要返回的欄位值和類型。
但是他仍然會返回Object陣列,但是此時不再使用ResultSetMetdata,而是明確的將\name和age按照String和int類型從resultset中取出。同時,也指明了就算query是使用*来查询的,可能獲得超過列出的這3個欄位,也僅僅會返回這3個欄位的值。

4. Join tables & 只傳回特定欄位值
  1. Query query = session.createSQLQuery(
  2. "SELECT ua.f_service FROM user_account ua INNER JOIN service_account sa ON ua.f_service=sa.id
  3. WHERE sa.account=:serviceAccount AND ua.account=:account AND ua.user_email=:emailAddress ")
  4. .addScalar("f_service",StandardBasicTypes.INTEGER)
  5. .setParameter("serviceAccount", serviceAccount)
  6. .setParameter("account", account)
  7. .setParameter("emailAddress", emailAddress);
  8.  
  9. resultList = query.list();
  10.  
  11. //get serviceId (createSQLQuery return Object[], but we only select f_service so only return an Object)
  12.  
  13. if (resultList.size() > 0) {
  14. Object aResult = resultList.get(0); //因為只有一個欄位值,所以傳回的並不是陣列,只是一個object
  15. serviceId = Integer.valueOf(String.valueOf(aResult));
  16. }
下列語法也通用
  1. Query query = session.createSQLQuery(
  2. "SELECT ua.f_service FROM user_account ua, service_account sa
  3. WHERE ua.f_service=sa.id and sa.account=:serviceAccount AND ua.account=:account AND ua.user_email=:emailAddress ")
要是有『多個查詢值 select a,b,c......』會返回object[],使用下列方法接取
  1. Object[] aResult = (Object[]) resultList.get(0);

5.透過addEntity、addScalar做join
http://blog.maxkit.com.tw/2014/03/hibernate-addentity-addscalar.html

2016年12月15日 星期四

Hibernate HQL - DML、DQL、JOIN 範例

HQL
-Select 
1.利用 ? 設定 sql 中的參數,搭配 query.setParameter("第幾個問號",變數);
  1. Session session = BackendHibernateUtil.getSession();
  2. List resultList = new LinkedList<>();
  3. try {
  4. Query query = session.createQuery("FROM CtrlSourceAreaEntity WHERE source_type = ?");
  5. query.setParameter(0,sourceType);
  6. resultList = query.list();
  7. } catch (HibernateException e) {
  8. log.error("XMLParserDAO @querySourceAreaId Fail:", e);
  9. } finally {
  10. session.close();
  11. }
  12. return resultList;
2.利用 :Name 設定參數
  1. "FROM CtrlSourceAreaEntity WHERE source_type = :sourceType"
  2. query.setParameter("sourceType",sourceType);

3.SQL Query In 設定參數
  1. Query query = session.createQuery("FROM ScheduleDownloadEntity WHERE status in (:statusNames) ORDER BY create_time ");
  2. query.setParameterList("statusNames", statusList);
  3. resultList = query.list();

-Update
1.executeUpdate()是執行DML的意思
  1. Query query = session.createQuery("UPDATE UserAccountEntity SET password = ? where f_service = ? AND account = ? AND user_email = ?");
  2. query.setParameter(0, userPasswordMD5);
  3. query.setParameter(1, serviceId);
  4. query.setParameter(2, account);
  5. query.setParameter(3, emailAddress);
  6. query.executeUpdate(); //這句是commit的意思

-Delete
1.executeUpdate() 是執行DML的意思

2.executeUpdate() 會傳回 int 影響的資料筆數
  1. Query query = session.createQuery("DELETE EdititemEntity WHERE kind = ? AND post_time BETWEEN ? AND ? ");
  2. query.setParameter(0, taskNumber);
  3. query.setParameter(1, startDate);
  4. query.setParameter(2, endDate);
  5. int resultCount = query.executeUpdate(); //可以取得DML影響的資料筆數

-Insert
1.將傳進來的 entity 實體 透過 session.save() 的方式把資料存進DB
  1. public void insertData(EdititemEntity edititemEntity) {
  2. Session session = Opv_lyHibernateUtil.getSession(); //Hibernate Session Connect
  3. Transaction tx = session.beginTransaction(); //一組交易
  4. try {
  5. session.save(edititemEntity); //將傳進來的Entity存進DB(透過Hibernate專屬方法)
  6. tx.commit(); //交易確認
  7. } catch (HibernateException e) {
  8. tx.rollback(); //交易取消
  9. log.error("CategoryDAO @insertData Fail,newsId={},error={}", edititemEntity.getId(), e);
  10. } finally {
  11. session.close();
  12. }
  13. }

HQL-Join

參考:
http://openhome.cc/Gossip/HibernateGossip/ManyToOne.html

多對一:
一個簡單的實體與實體間之關係為『多對一』的關係,例如『使用者』與『房間』的關係就是多對一的關係,多個使用者使用同一房間。

範例目標:

A:每個 user 有特定的 serviceId(f_service) ,多個user會對上同一個serviceId,希望透過HQL的方式,取得user時,順便取得service_account




1.實體設定(UserAccountEntity)

-在多對一的情況下,『多』的實體才需要特別設定,『一』的部份不用調整,因此我們只調整UserAccount
-UserAccountEntity.class
UserAccountEntity類別中有一serviceAccountEntity屬性,將參考至serviceAccountEntity實例,多個User實例可共同參考一個service實例











2.設定檔(UserAccountEntity.hbm.xml)
- class="絕對路徑""
- column="f_service" → userAccount的f_service(FK)會去參考到serviceAccount的id(PK),兩張table才會連結在一起
- cascade表示主控方(User)進行save-pdate、delete等 相關操作時,被控 方(Room)是否也一併進行相關操作,簡單的說,也就是您儲存或更新User實例時,被參考到的Room實例是否一併對資料庫發生儲存或操作,設定為 all,表示主控方任何操作,被控方也進行對應操作。

-把原先的fService先註解掉



-設定mana-to-one的參數















3.查詢結果
- 重要:INNER JOIN 是 userAccount實體中的serviceAccount屬性




- 結果
每個傳回的結果都帶有UserAccountEntity & ServiceAccountEntity