發表文章

VBA EXCEL 工作表變化 馬上執行 的作法 Worksheet_Change

圖片
沒想到還會用到 Excel 中的 VBA,當初寫VBA就是一段窮極無聊的日子,用Excel寫星象表… 現在居然要幫一位老大哥寫這樣的程式…當真所有的事,當下是很難知道它發生的意義是什麼… 癈話不多說 先開啟EXCEL,存成副檔名為xlsm,這樣可以使用巨集功能。 然後看一上面,標籤列,有無開發人員選項。 如果沒有,從 檔案->選項->自定功能區->開發人員(打勾) 如果有,點擊 visual basic,就可以開始寫VBA 我們的目的是這樣的,如果 worksheet中有任何的更動,都會執行一段程式。 所以我們先點擊左邊的工作表1,然後右邊的程式編輯欄中上面的選擇列中,選worksheet。要記得這個設定是 對應到個別的worksheet ,所以如果有其它工作表,要個別寫對應的程式。如下 接下來選右邊的change 選完就會自動產生兩個程式名。 Worksheet_Change與 Worksheet_SelectionChange,如下。Worksheet_Change是指任何在worksheet 上的變動,就會執行這個程式。Worksheet_SelectionChange是指,選定EXCEL中的格有變化,如本來選A1改點擊了B1,這個動作就會觸發Worksheet_SelectionChange。 我們在兩個程式中寫一個MsgBox, 如下 各位可以試試效果如何。只要點擊左上方,excel的小圖,就會回到excel的worksheet中。 我們在 Worksheet_Change中增加三行程式,會在A1, A2, A3格中填入a, b, c。 各位是否有推論,這樣的寫法,會產生無窮迴圈? 這個很重要!在寫 Worksheet_Change程式時,要很小心,如果是 工作表1自己的 Worksheet_Change要對工作表1自己做改變,就會進入無窮迴圈。 所以我們要能自由的開關觸發功能。用   Application.EnableEvents  我們加入  Application.EnableEvents ,再試試看。...

Minst 手寫訓練集 python

圖片
以往我們有一個新的類神經訓練模型,我們都會用single pole或是double pole來測試模型的訓練結果。以目前類神經網路發展的狀況,single pole 與double pole已不能滿足需求。進一步,我們會使用MNIST訓練集來訓練。網址在此 http://yann.lecun.com/exdb/mnist/ 一進去我們就看到三個作者 Yann LeCun, Corinna Cortes, Christopher J.C. Burges,我們向他們致敬。 然後就是四個重要的檔案。 train-images-idx3-ubyte.gz :  training set images (9912422 bytes) train-labels-idx1-ubyte.gz :  training set labels (28881 bytes) t10k-images-idx3-ubyte.gz :   test set images (1648877 bytes) t10k-labels-idx1-ubyte.gz :   test set labels (4542 bytes) 第一跟第二個是拿來訓練用的,第三跟第四個是拿來測試的。我們可以注意到有image跟labels兩種檔。image是圖檔,labels是對應圖檔的答案。 雖然TensorFlow有方便的讀取方法。但如果我們想要自己用python讀來用。要如何做呢? 我們要先看一下網頁中的這部份 我們可以看到offset,代表讀的byte數。就是說我們開了檔之後。read進來,以label檔來說,data[0:4]會等於2049。data[4:8]等於60000。 了解檔案的格式,我們就可以寫一個小程式來讀讀看。 因為offset是4個為一個單位,所以我們先寫一下轉byte為數字的程式 def b2i(b):     return int(codecs.encode(b, 'hex'), 16) with open("."+os.sep+"train-images.idx3-ubyte", 'rb') as f:     data = f.r...

python 變數 II

有時候我們在多個不同的class之間使用了同一個模組。而模組中有些變數,我們希望其可以跟著變動。 我們舉個例子來看看 第一個檔案 vv.py import os, sys class vv(): vva = 1 vvb = 2 第二個檔案 v1.py import vv class v1(): def __init__(self): self.aa = vv.vv()                 self.aa.vva=9999 def show(self): print self.aa.vva print self.aa.vvb 第三個檔案為主程式 vmain.py import vv import v1 class main(): def __init__(self): self.a = v.vv() def show(self): print self.a.vva print self.a.vvb def change(self): self.a.vva=12345 self.a.vvb=54321 def gotV1(self): aa = v1.v1() aa.show()      if __name__ == '__main__': aa=main() aa.show() aa.change() aa.show() aa.gotV1() print " new object " bb = main() bb.show() 當我們執行了vmain.py 得到 1 2 12345 54321 9999 2  new object  1 2 我們企圖在change中改變vva的數字,。這個合理,每一個新的物件,都該保有其參數原來的值。如果我們希望new...

python aubio 安裝

圖片
在window 10,以pip 安裝 aubio時出現如下的錯誤。這是安裝環境的問題。 Running "pkg-config --libs --cflags libavformat" failed: WindowsError(2, 'The system cannot find the file specified') Running "pkg-config --libs --cflags libavutil" failed: WindowsError(2, 'The system cannot find the file specified') Running "pkg-config --libs --cflags libavresample" failed: WindowsError(2, 'The system cannot find the file specified') Running "pkg-config --libs --cflags jack" failed: WindowsError(2, 'The system cannot find the file specified') Running "pkg-config --libs --cflags sndfile" failed: WindowsError(2, 'The system cannot find the file specified') Running "pkg-config --libs --cflags samplerate" failed: WindowsError(2, 'The system cannot 我們要為 widnow 環境安裝上 visual C++, 如下說明 https://wiki.python.org/moin/WindowsCompilers 在安裝前,我們先確定setup tool為新的 pip install --upgrade setuptools 針對自己的python選Visual C++ 在連結中...

Python global variable

def g():     var =1     print var var = 10 print var g() print var  答案為 >>>  10 1 10 >>>  這個很容易理解,本來g()裡面的參數就不會跟外面的混為一談。 def g():     print var var = 10 print var g() print var  答案為 >>>  10 10 10 >>>  超有趣,g()中的var,居然直接找到外面的var。 def g():     print var global var var = 10 print var g() print var  答案為 >>>  10 10 10 >>>  多宣告global,跟上一種寫法一樣。好像內定就以為是global def g():     var = 1     print var global var var = 10 print var g() print var  答案為 >>>  10 1 10 >>>  g()中多了var = 1怎麼又認為不是外部的var了呢?外部var明明有宣告為 global了。這樣就可理解,上兩種寫法,因為沒有在 g()中給定 var 一個值。所以python 認為g()裡面的var與外面的是一樣的。所以給一個值,python會做出新變數。這樣我們可以推論,如果有沒新宣告為global不能給值。 >>> global v = 1 SyntaxError: invalid synta...

python 繼承

import ttk import re import os, sys class Computer(): keyboard = "bluetooth" mouse = "bluetooth" def __init__(self, keyboard = "wire", mouse = "wire"): self.keyboard = keyboard self.mouse = mouse def getKeyboard(self): print "keyboard is " + self.keyboard def getMouse(self): print "mouse is " + self.mouse def changeKeyboard(self, keyboard): self.keyboard = self.keyboard + "-" + keyboard print self.keyboard class Server(Computer): interface = "scsi" harddisk = "SD" def __init__(self, keyboard="wire", mouse = "wire", interface = "ide", harddisk = "drive"): Computer.__init__(self, keyboard, mouse) #這裡在python 3要改成 super().__init__(keyboard, mouse) self.interface = interface self.harddisk = harddisk def chang...

tkinter check button

先宣個一個參數的物件 varB = tk.BooleanVar() set  初始值 varB.set(True) 給 check button 設定 var 參數 ckBtn = tk.Checkbutton(root, text="I am a check button",var=varB) ckBtn.grid(row=0, column =  0) 想要得到參數 ckBtn.get() 如 if  ckBtn.get() is True:     print "I am true" 也可以把參數換成String varB = tk. StringVar() 給 check button 設定 var 參數 ckBtn = tk.Checkbutton(root, text="i am a check button", var=varB, onvalue="yes", offvalue="no") 想要得到參數  ckBtn.get() 如 if  ckBtn.get() == "yes":         print "I am yes"