2019年7月22日 星期一

京城銀行 手機線上提領西聯匯款 圖文教學

京城銀行 手機線上提領西聯匯款 圖文教學

線上提醒比銀行簡單太多惹~

網路提領

我使用的是京城銀行的網路銀行功能,要事先到銀行開戶,並告知要使用網銀等等,如果不知道怎麼做直接跟他說,你要從手機提領西聯匯款應該就可以了。
實體帳戶開完之後手機還要開通歐,她會給你一個一次性密碼條開通,你要輸入到APP才可以激活,啟用後只有這台手機可以動帳戶金額;別台手機不行(就算有你的網銀帳密),換手機要帶雙證件去銀行重拿一組密碼,那啟用碼一次性的。
但是其實就是一般數位銀行的手續而已各家都一樣。如果你是新手第一次辦網銀,建議就是當場就請行員手把手交你,跟她說我手機怎麼設定。

設置完畢之後底下是如何提領的流程

首先打開APP進入西聯匯款頁面(這邊可能會出現要求你登入)
點擊匯入
同意說明書
填入匯款單 (WTF這邊比銀行填單簡單太多了,銀行要填一大堆)
只要填入MTCN號碼與匯款人姓名、在選個國家即可,都在剛剛的收據上的紅框那裏
匯款人的部分有姓與名兩個欄位必填,這邊我是拆成底下這樣
名:Google Asia Pacific Pte.
姓:Ltd.
下一步就可以提醒摟
提領是馬上就會好的,可以到帳戶內看到金額已匯入

Google Adsence 西聯匯款如何領取

Google Adsence 西聯匯款如何領取

前置步驟

Google Adsence 在累積到一定金額之後就可以開通地址驗證了,這邊我查網路上好像是說10美元的樣子。有點久了印象中就是右上角鈴鐺自己會跳出來要你輸入真實地址驗證,這邊不要亂填,她真的會寄一封實體信件給你,裡面有pin碼,你要輸入完成地址驗證才可以正式開通。
驗證完畢之後還有一關是需要你選擇哪一種付款方式,個人小額建議填西聯匯款,沒有手續費的樣子,我上次領100多美元是實領3200多。
設定的位置在這個地方

提領資訊

金額累計到設定的最低金額之後就會配發了,配發的日期通常在每個月21日,你會收到gmail的信件
這時候回到你的 https://www.google.com/adsense 主頁就會發現金額被扣除了
需要查找西聯匯款的數據可以,點擊左邊的付款,查看交易紀錄。
這邊點入 (這張圖箭頭所指的地方只有發錢的時候有,平時是不會有的你找不到的)
收據內就有跟你說提醒要填的東西
西聯匯款只要填對,對方資訊+自己的資訊,然後再給身分證證明本人,就可以提領了。
提領方式就算是第一次提領,我也建議你用線上的方式,線上網銀也是可以當場辦好的,比填單方式方便很多,那個西聯匯款實體單子要寫蠻多的。
直接跟行員說要辦線上提領西聯匯款,叫行員教你怎麼開通網銀,好了之後直接在現場用手機提領,不懂就直接問叫她手把手教你,流程都不是太麻煩,都是一下子就能好的,不用擔心弄很久。

銀行提領

填單子而已,一個蘿蔔一個坑,前面收據紅色框框內的資訊是會用到的,剩下的都自己的資料,全部都要寫英文,會需要用到台灣的英文地址,記得先到郵局查一下英文地址~
(地址要跟收據上的一樣歐,圖中我碼掉了在紅框下那個,不然領不到)
這邊我第一次去銀行領的時候,行員超不客氣的,我不知道哪一個要填哪一格,問了行員,行員跟我說我怎麼知道,這些你自己應該要知道阿!((好像怕我盜領似的QQ
要去之前建議先看一下紅框內的資訊,個別代表是什麼。但其實也不是太難拉,只是第一次去有點緊張。內容舉例來說哪個單字是國家、銀行名稱,街道名稱,這些而已,冷靜下來應該不會填錯才是。

線上提領

我使用的是京城銀行的APP,線上提領比起去銀行填單提領簡單超多的ㄚㄚ
只要填入 MTCN、匯款人姓名、國家 這三項資訊就可以提領了,銀行的單子要填超多的…
篇幅有一點長,文章另外寫一篇,可以連結到這裡參考
https://charlottehong.blogspot.com/2019/07/blog-post.html

2019年7月2日 星期二

C 動態陣列 範例與解說

C 動態陣列 範例與解說

其實是看到有人在社團問問題,順道寫了程式,不過當我弄完的時候才發現早就關閉回應了QQ
好吧自己發部落格XD

動態陣列

顧名思義,意思是說當你需要用到多大的陣列才向系統要求多大的記憶體,一般如果直接寫在宣告上的陣列,是程序一打開的瞬間就向系統要求記憶體,這種一開始就要求的記憶體是有限的不能塞太大的。
其次使用動態陣列也可以節省空間,如果初期並不知道空間大小,而是計算後才能知道總共要多大,直接寫在宣告上,只能多寫一點避免到時候不夠。動態陣列就沒關係了,程序執行後計算出來再要求記憶體即可。

宣告方法

介紹最基本的兩個函式
int* p=NULL;
int len=5;

// 要求空間
p = (int*)calloc(len, sizeof(int));     // 陣列內容會初始化為0
p = (int*)malloc(len* sizeof(int));   // 陣列內容不會初始化,可能是亂碼垃圾值
兩個簡單就差別是否初始化,根據使用情況調整使用就好,其中要注意的是 malloc 只有一個參數,calloc則是有兩個參數,所以可以看到其中一個是逗號跟乘號(這不是打錯)。

檢測

獲取之後就可以使用了,但是再使用前要先檢查是否有成功要到記憶體,電腦的記憶體是有限的,如果你要求一個超大的,大於當前記憶體容量,系統不會給你的,這種情況下函式會返回NULL,所以類似於底下的方法就可以檢測是否成功。
if(p){
    printf("成功");
} else {
    printf("失敗");
}
當然啦現在電腦記憶體都很大,寫作業基本上應該是不會遇到NULL的情況,但是即便如此,我還是建議你養成習慣寫一下,以後寫大專案的時候你會感謝你自己的。
另外記憶體的不足不只發生在記憶體空間不構的情況,如果程序長時間運行,不斷的解構重購,會造成記憶體破碎,就是說一段有使用,一段沒使用,記憶體中間是有間格的,上述的兩種要求方法,要求的情況是連續記憶體,在這種記憶體破碎嚴重的情況下,即便記憶體充足也可能要不到,系統找不到足夠長的連續空間。

使用

使用就很簡單了,要求到的記憶體要用第幾個,直接加上去就好,編譯器會自動幫你計算位置的,最後再使用星號取值即可。
for (int i; i<len; ++i){
    prinf("%d", *(p+i));
}

解構

用完之後要記得把記憶體回收,告訴系統這個我不用了,這樣下次你要求空間的時候,原本這一段也可以被列入使用,不回收的話,這個空間就一直佔著誰也不能用。
如果你再還沒回收之前就把那個記憶體位址給丟失了,也就是那個P你改成別的值,那就再也沒有人知道,那一段記憶體在哪裡,你就沒有辦法釋放那塊記憶體了,這種情況叫做 memroy leak。
倒是不用擔心練習程式忘記釋放記憶體,結果記憶體被偷吃滿,以目前的作業系統來說是會自動幫你把記憶體回收掉的,不會讓你做這種傻事,作業系統知道這隻程式從頭到尾到底要了那些記憶體,既然都把程式關了,當然全部都回收瞜。
解構的方法很簡單,只是一個函式
free(self->p);
self->p=NULL;
free即可解構,後面的設置成NULL是一種保險,也是一種聲明,既然都解構掉了代表這塊記憶體不能用了,還留著指標幹嘛,不知道知情的人傻傻的拿去用了就罪過了(這個叫未定義行為)。當設置成NULL,別人就用不了了,同時也可以用if來判斷已解構。
不要想說反正記憶體充足就不解構,這個習慣真的很重要,以後寫大專案的時候沒有養成習慣,真的會抓蟲抓的不要不要的。不解構甚至過分點leak,不只影響到記憶體用量,有時候還可能導致非預期的行為,導致你抓蟲的時候沒得下手,怎麼想都奇怪,這時候就來不及了,只能加油吧,祝好運XDD。
抓蟲第一件事情,先把釋放還有leak做好,真的是不是開玩笑的,沒有嚴謹的照規矩寫的程式,很多時候補上就莫名其妙好了,然後完全不知道發生什麼了,乾怎麼好了!

範例

最後附上簡單寫的範例,可以對照著參考
/*****************************************************************************
Name : 動態陣列
Date : 2019/07/02
By   : CharlotteHonG
Final: 2019/07/02
*****************************************************************************/
#include <iostream>
using namespace std;

struct Arr {
    int* p;
    int len;
};

void Arr_ctor(Arr* self, int len) {
    int*p = NULL;
    p = (int*)calloc(len, sizeof(int));

    if(p){
        self->p   = p;
        self->len = len;
    } else {
        printf("Error Arr_ctor.");
    }
}
void Arr_set(Arr* self, int idx, int num) {
    int* p = self->p;
    int len = self->len;

    if(idx>=0 && idx < len){
        *(p+idx) = num;
    } else {
        printf("Error Arr_set");
    }
}
void Arr_dtor(Arr* self) {
    free(self->p);
    self->p=NULL;
    self->len=0;
}
void Arr_print(Arr* self) {
    for(size_t i = 0; i < self->len; i++){
        int* p = self->p;
        printf("%d, ", *(p+i));
    } printf("\n");
}
//=============================================================================
int main(int argc, char const* argv[]) {
    // 陣列長度
    int len = 10;

    // 建立陣列 (初始值為0)
    Arr array;
    Arr_ctor(&array, len);
    // 打印
    Arr_print(&array);
    // 更改數值
    for(size_t i = 0; i < len; i++){
        Arr_set(&array, i, i+1);
    }
    // 打印
    Arr_print(&array);
    // 釋放資源
    Arr_dtor(&array);

    return 0;
}
//=============================================================================

2019年6月8日 星期六

如何完整的轉移 安裝 chrome 已下架的擴充套件

如何完整的轉移 安裝 chrome 已下架的擴充套件

我繞了好長一段路,失敗了好幾次都是用封裝的方式,問題在於下架之後是不允許安裝的,
我還特地去弄了如何讓chrome允許第三方的方法
最後也是失敗告場,雖然沒有出現允許打開了,可是打開還是爆掉…….
抽取 chrome 已下架的擴充套件安裝後會顯示錯誤,最後還是失敗收場
最後是我不死心的又測試了一次,終於成功了!
主要的想法之前有看過一篇文章是直接整個資料夾複製下來,不封裝直接轉移到新電腦,然後要把某個資料夾內容刪除,那是原本使用者上的電腦。我找不到這篇文章了,我就沒砍直接整份過來,然後就成功了!連設置也一起過來了,嗚哇天啊太好了。
不過這可能是因為我是使用同一個帳號!不同帳號可能要砍那個資料夾,我印象中記得是 _locales
好啦正文開始,剛剛弄好太開心了,這篇會以 Flavr - Custom New Tab & Google™ Background 來介紹轉移過程。

複製檔案資料

第一步先到你原先有安裝的電腦上的這個位置
%USERPROFILE%\AppData\Local\Google\Chrome\User Data\Default\Extensions
這是相對位置,直接貼上資料夾上位址處即可,近來之後要找到你的套件的ID
也就是這一個,資料夾名稱就是這個整個複製下來就是了。
然後轉移到新的電腦上,在chrome擴充元件的頁面上先打開,開發人員模式就可以載入為封裝程序了。
這邊要注意,資料夾的位置先想個位置放好,如果事後刪除了該資料夾,那麼在chrome上擴充元件也會失效。
然後就是選到你的資料夾之後按確定就好了!不過我不知道為什麼按第一次之後資料夾消失,且並沒有出現,我是按第二次才好了。

後續

  • 實際上,上一篇系統管理範本是不需要安裝的,我後來移除了了一切正常。
  • 開發人員模式安裝完畢就可以關閉了。
  • 你的擴充元件上面會有一個紅色的標記,說你這是未封裝軟件。

2019年6月3日 星期一

Youtube 自動暫停播放 怎麼讓它不暫停

Youtube 自動暫停播放 怎麼讓它不暫停

不知道什麼時候改版之後YT播放清單變得不像以前可以一直撥了,撥到一定時間之後就自動暫停了,解決辦法是直接安裝插件繼續播放,不過還是會看到暫停畫面就是了,但是會繼續撥。
安裝之後重新啟動瀏覽器就有作用摟~

2019年5月27日 星期一

Adobe Reader 開啟時自動隱藏右邊搜索工具列

Adobe Reader 開啟時自動隱藏右邊搜索工具列

到設定裡面更改這個設置
然後再把右邊的小框框關閉,下次開起的時候就會維持關閉狀態了。

2019年5月3日 星期五

[圖文] Python-OpenCV 4.1.0 安裝配置在 Visual Studio 2019

[圖文] Python-OpenCV 4.1.0 安裝配置在 Visual Studio 2019

如果是配置自己環境上的Python可以參考這篇
https://charlottehong.blogspot.com/2015/08/windows-install-opencv-for-python.html

這篇會從頭開始講~包含怎麼布置python的執行環境。
Visual Studio 2019已經做得相當完備了,功能也簡化了,不再是以前2017與2015版本很多功能可能不是很好使,這會是我優先推薦的編譯器。
唯一的缺陷就是太肥了吧,不過這在VS19也有很大的改善,整理效能損耗減少非常之多,詳細可以搜尋相關文章,至少記憶體需求減少了非常之多,這次微軟真的是猛起來想把VS19做好了。
事前不需要到 Python 官方下載安裝,VS19會自己有自己的Python。如果已經安裝了預設也是使用內建的,但是可以選用自己安裝的Python。

布置環境

首先打開他的環境配置,可以直接在開始搜尋 Visual Studio Installer 這個就可以找到並打開了。
然後按下變更
把這個勾起來就可以使用了,勾好之後右下角的變更按下去就會開始安裝了

運行代碼

然後開打VS,選擇建立新專案
建立之後選擇Python
名稱可以自由修改我這邊是打 OpenCV_Test 打好之後就建立吧
紫色框框的部分是可以自由選擇版本的,這裡的環境是VS自己內建的不是你系統上自己安裝的。
那個下拉選單點擊之後可以新增環境,如果需要用自己系統上安裝的環境,可以手動新增進去然後就可以使用了。
測試可以先隨意打幾行代碼
# -*- coding: utf-8 -*-
print('Test')
然後按下F5就可以執行了

安裝Python套件

點擊python旁邊禮物形狀的按鈕,可以打開套件管理介面。
然後搜尋 opencv-python 安裝 opencv-contrib-python 這個版本,
[1] 左上角看到我有兩個版本 Python2.7 與 Python3.7,這邊2.7版是我自己到官方下載安裝的,內建只會有 Python3.7版)
[2] contrib會多安裝那些在商業上需要付費,但是個人使用免費的函式庫。如果沒用到,安裝最下面那個不帶contrib字樣也是可以使用。
[3] 我有發現VS19安裝好python就自帶numpy了,如果沒有這個要自己安裝。跟上面安裝方法一樣,在套件管理處搜尋 numpy 安裝就可以了。
然後會跳出來說要提高權限,按第一個提高即可。
安裝完畢就貼上測試的代碼試試看
# -*- coding: utf-8 -*-
import cv2
import numpy as np

#  畫布大小
img = np.zeros((720,1280,3), np.uint8)
# (位置),大小,(顏色)粗度
cv2.circle(img,(200,200), 100, (0,0,255), 2)
# (第一個座標)(第二個座標)(顏色),粗度
cv2.rectangle(img,(350,100),(550,300),(0,255,0),3)
# (第一個座標)(第二個座標)(顏色),粗度
cv2.line(img,(600,100),(800,300),(255,0,0),10)

pts = np.array([[10,5],[20,30],[70,20],[50,10]], np.int32)
pts = pts.reshape((-1,1,2))
cv2.polylines(img,[pts],True,(0,255,255))

font = cv2.FONT_HERSHEY_SIMPLEX
# (座標),大小,(顏色),粗度
cv2.putText(img,'Charlotte.HonG',(0,500), font, 5,(255,255,255),10)

while(1):
    cv2.imshow('Dring',img)
    if cv2.waitKey(20) & 0xFF == 27:
        break
cv2.destroyAllWindows()
直接執行吧~
恭喜完成瞜~