vba函數(shù)參考手冊(vba do while循環(huán)語句舉例)

大家好,今天來為大家解答vba函數(shù)參考手冊這個問題的一些問題點,包括vba do while循環(huán)語句舉例也一樣很多人還不知道,因此呢,今天就來為大家分析分析,現(xiàn)在讓我們...
大家好,今天來為大家解答vba函數(shù)參考手冊這個問題的一些問題點,包括vba do while循環(huán)語句舉例也一樣很多人還不知道,因此呢,今天就來為大家分析分析,現(xiàn)在讓我們一起來看看吧!如果解決了您的問題,還望您關(guān)注下本站哦,謝謝~
vba sub函數(shù)參數(shù)
sub是子程序沒有返回值,無需定義返回值類型。Sub過程有兩種方法:
以下兩個語句都調(diào)用了名為MyProc的Sub過程。
CallMyProc(FirstArgument,SecondArgument)
MyProcFirstArgument,SecondArgument
注意當(dāng)使用Call語法時,參數(shù)必須在括號內(nèi)。若省略Call關(guān)鍵字,則也必須省略參數(shù)兩邊的括號。
excel vba 常用函數(shù)
1、VBA肯定能調(diào)用工作表函數(shù),調(diào)用方法也是很簡單,只需在函數(shù)名稱前面加上:Application.WorksheetFunction.函數(shù)名(參數(shù))。
其參數(shù)的使用規(guī)則與在工作表中使用要求完全一致。除了能調(diào)用工作表函數(shù),VBA自身內(nèi)置也有很多函數(shù)可以使用。因為是VBA自身內(nèi)置的函數(shù),所以在使用時,在前面可以加上:VBA.函數(shù)名,也或者直接調(diào)用寫函數(shù)名。經(jīng)常有人可能用不同版本的辦公程序打開有代碼的工作簿,結(jié)果就有可能會出現(xiàn)如“找不到工程或庫”的提示。怎么辦呢?如果是因為VBA自身內(nèi)置函數(shù)的原因,則可以在前加上“VBA.”就行了。
當(dāng)然,也可在VBE界面中菜單【工具】->【引用】打開引用對話框,查找?guī)Ч错椫泻皝G失…”、“找不到…”、“MISSING…”的條目,并取消勾選,確定,基本就可以了?,F(xiàn)在總結(jié)下常用的VBA自身內(nèi)置函數(shù)如下(中間文字過長,或以跳轉(zhuǎn)到最下面看看“其他常用函數(shù)”,很有用的哦。):
2、測試類函數(shù):
IsNumeric(x)-是否為數(shù)字,返回Boolean結(jié)果。
IsDate(x)-是否是日期,返回Boolean結(jié)果。
IsEmpty(x)-是否為Empty,返回Boolean結(jié)果。
IsArray(x)-指出變量是否為一個數(shù)組。
IsError(expression)-指出表達(dá)式是否為一個錯誤值。
IsNull(expression)-指出表達(dá)式是否不包含任何有效數(shù)據(jù)(Null)。
IsObject(identifier)-指出標(biāo)識符是否表示對象變量。
3、數(shù)學(xué)函數(shù):
Sin(X)、Cos(X)、Tan(X)、Atan(x)-三角函數(shù),單位為弧度。
Log(x)、Exp(x)-返回x的自然對數(shù),指數(shù)。
Abs(x)-返回x的絕對值。
Int(number)、Fix(number)-都返回參數(shù)的整數(shù)部分,區(qū)別:Int將-8.4轉(zhuǎn)換成-9,而Fix將-8.4轉(zhuǎn)換成-8。
Sgn(number)-返回一個Variant(Integer),指出參數(shù)的正負(fù)號。
Sqr(number)-返回一個Double,指定參數(shù)的平方根。VarType(varname)-返回一個Integer,指出變量的子類型。
Rnd(x)-返回0-1之間的單精度數(shù)據(jù),x為隨機種子。
Round(x,y)-把x四舍五入得到保留y位小數(shù)的值。
4、字符串函數(shù):
Trim(string)、Ltrim(string)、Rtrim(string)-去掉string左右兩端空白,左邊的空白,右邊的空白。
Len(string)-計算string長度
Replace(expression,find,replace)-替換字符串。
Left(string,x)、Right(string,x)、Mid(string,start,x)-取string左/右/指定段x個字符組成的字符串Ucase(string)、
Lcase(string)-轉(zhuǎn)換字符串為大、小寫Space(x)-返回x個空白的字符串
Asc(string)-返回一個integer,代表字符串中首字母的字符代碼
Chr(charcode)-返回string,其中包含有與指定的字符代碼相關(guān)的字符
InStr()-返回一個字符串在另外一個字符串中的位置,返回值為Variant(Long)型。
5、轉(zhuǎn)換函數(shù):
CBool(expression)-轉(zhuǎn)換為Boolean型
CByte(expression)-轉(zhuǎn)換為Byte型
CCur(expression)-轉(zhuǎn)換為Currency型
CDate(expression)-轉(zhuǎn)換為Date型
CDbl(expression)-轉(zhuǎn)換為Double型
CDec(expression)-轉(zhuǎn)換為Decemal型
CInt(expression)-轉(zhuǎn)換為Integer型
CLng(expression)-轉(zhuǎn)換為Long型
CSng(expression)-轉(zhuǎn)換為Single型
CStr(expression)-轉(zhuǎn)換為String型
CVar(expression)-轉(zhuǎn)換為Variant型
Val(string)-轉(zhuǎn)換為數(shù)據(jù)型
Str(number)-轉(zhuǎn)換為String
5、時間函數(shù):
Now、Date、Time-返回一個Variant(Date),根據(jù)計算機系統(tǒng)設(shè)置的日期和時間來指定日期和時間。
Timer-返回一個Single,代表從午夜開始到現(xiàn)在經(jīng)過的秒數(shù)。
TimeSerial(hour,minute,second)-返回一個Variant(Date),包含具有具體時、分、秒的時間。
DateDiff(interval,date1,date2[,firstdayofweek[,firstweekofyear]])-返回Variant(Long)的值,表示兩個指定日期間的時間間隔數(shù)目。
Second(time)-返回一個Variant(Integer),其值為0到59之間的整數(shù),表示一分鐘之中的某個秒。
Minute(time)-返回一個Variant(Integer),其值為0到59之間的整數(shù),表示一小時中的某分鐘。
Hour(time)-返回一個Variant(Integer),其值為0到23之間的整數(shù),表示一天之中的某一鐘點。
Day(date)-返回一個Variant(Integer),其值為1到31之間的整數(shù),表示一個月中的某一日
Month(date)-返回一個Variant(Integer),其值為1到12之間的整數(shù),表示一年中的某月。
Year(date)-返回Variant(Integer),包含表示年份的整數(shù)。
Weekday(date,[firstdayofweek])-返回一個Variant(Integer),包含一個整數(shù),代表某個日期是星期幾。
其它常用函數(shù):
Shell-運行一個可執(zhí)行的程序。
InputBox-這個太熟悉了,簡單輸入對話框。這個需要注意與Application.InputBox(更強大,內(nèi)置容錯處理,選擇取消后返回false)區(qū)分,而這個函數(shù)不含有容錯處理,而且選擇取消后返回空串(零個字節(jié)的字符串)。
MsgBox-這個更不用說了,簡單信息顯示對話框,其實也是一種簡單的輸入手段。
Join-連接數(shù)組成字符串。
Split-拆分字符串成數(shù)組。
RGB-返回指定R、G、B分量的顏色數(shù)值。
Dir-查找文件或者文件夾。
IIF(expression,truePart,falsePart)-IF語句的“簡化版本”(比喻,當(dāng)然并不一樣);expression為true的話返回truePart,否則返回falseParth。Choose(index,choice1,...choiceN)-選擇指定Index的表達(dá)式,Index可選范圍是1到選項的總數(shù)。
Switch(exp1,value1,exp2,value2,...expN,valueN)-從左至右計算每個exp的值,返回首先為true的表達(dá)式對應(yīng)的value部分。如果所有的exp值都不為true,則返回Null。注意雖然只返回一個部分,但是這里所有的表達(dá)式exp1到expN都是要被計算的,實際使用中要注意這個副作用。
vba怎么寫代碼函數(shù)公式
把提取字符的公式寫入sheet2單元格Subaa()Sheet2.Range("A1").Formula="=left(sheet1!A1,5)"EndSub直接把結(jié)果寫入sheet2單元格subaa()sheet2.range("A1").value=left(sheet1.range("A1").value,5)endsub
vba怎樣計算表格中原有數(shù)據(jù)
vba的countif函數(shù)使用:
許多EXCEL問題都涉及數(shù)據(jù)計數(shù),對于一些簡單的計數(shù),通常使用COUNT函數(shù)或COUNTA函數(shù)就可以解決。然而,在實際的業(yè)務(wù)處理當(dāng)中,往往存在諸多條件的限制,僅僅使用簡單的統(tǒng)計函數(shù)是無法滿足人們的實際需求的,例如多條件計數(shù)、統(tǒng)計不重復(fù)個數(shù)等。
例如,在一個EXCEL表格中,D列是考生的數(shù)學(xué)考試成績,我們想統(tǒng)計數(shù)學(xué)成績及格的人數(shù)??梢允褂谩?COUNTIF(D:D,">=60")”來實現(xiàn)。
本例中,COUNTIF函數(shù)可以對區(qū)域中滿足單個條件的單元格區(qū)域進(jìn)行計數(shù)。語法如下:
COUNTIF(參數(shù)一,參數(shù)二),其中參數(shù)一為需要計算其中滿足條件的單元格數(shù)目的單元格區(qū)域,參數(shù)二是用于定義將對哪些單元格進(jìn)行計數(shù)的數(shù)字、表達(dá)式、單元格引用或文本字符串。
COUNTIF函數(shù)的常見用法如下:(假如數(shù)據(jù)所在單元格區(qū)域命名為“Data”)
公式說明:
=COUNTIF(Data,"=")返回真空單元格個數(shù)(真空單元格是指什么都沒有的單元格)
=COUNTIF(Data,"")返回真空+假真空單元格個數(shù)(假真空是指0字符的空文本)
=COUNTIF(Data,"<>")
返回非真空單元格個數(shù)
=COUNTIF(Data,"*")
返回文本型單元格個數(shù)
=COUNTIF(Data,"<9.99E+307")
返回數(shù)值型單元格個數(shù)
=COUNTIF(Data,"<>""")返回區(qū)域內(nèi)所有單元格個數(shù)
=COUNTIF(Data,"<0")返回偶包含負(fù)值的單元格個數(shù)
=COUNTIF(Data,"<>0")返回真不等于零的單元格個個數(shù)
=COUNTIF(Data,60)
返回值等于60的單元格個數(shù)
=COUNTIF(Data,">60")返回值大于60的單元格個數(shù)
=COUNTIF(Data,"<60")返回值小于60的單元格個數(shù)
=COUNTIF(Data,">=60")
返回值大于等于60的單元格個數(shù)
=COUNTIF(Data,"<=60")
返回值小于等于60的單元格個數(shù)
=COUNTIF(Data,A1)
返回值與A1單元格內(nèi)容相同的單元格個數(shù)
=COUNTIF(Data,">"&A1)返回值大于A1單元格內(nèi)容的單元格個數(shù)
=COUNTIF(Data,"<"&A1)返回值小于A1單元格內(nèi)容的單元格個數(shù)
=COUNTIF(Data,"???")
返回字符等于3的單元格個數(shù)
=COUNTIF(Data,"YDL")
返回值等于YDL的單元格個數(shù)
=COUNTIF(Data,"YDL?")
返回以字母YDL開頭且字符數(shù)等于4的單元格個數(shù)
=COUNTIF(Data,"YDL*")
返回以字母YDL開頭的文本單元格的個數(shù)
=COUNTIF(Data,"?YDL*")
返回第2,3,4字符為YDL的單元格個數(shù)
=COUNTIF(Data,"*YDL*")
返回含的YDL字符的單元格個數(shù)
=COUNTIF(Data,"*"&A1&"*")
返回包含A1單元格內(nèi)容的文本單元格個數(shù)
=COUNTIF(Data,TODAY())返回值等于當(dāng)前日期的單元格個數(shù)
=COUNTIF(Data,">"&AVERAGE(Data))返回大于均值的單元格個數(shù)
=SUM(COUNTIF(Data,">"&{10,15})*{1,-1})
返回大于10小于等于15的單元格個數(shù)
=SUM(COUNTIF(Data,{TRUE,FALSE}))
返回包含邏輯值的單元格個數(shù)
特別指出的是,在EXCEL2010中,新增了一個多條件計數(shù)函數(shù),那就是“COUNTIFS”,假如在一個EXCEL表格中,D3:D50單元格的內(nèi)容是職工的年齡,E3:E50單元格的內(nèi)容是是否有房,F(xiàn)3:F50單元格的內(nèi)容是是否有車,那么統(tǒng)計職工中35歲以上有房有車的人數(shù)應(yīng)該用如下公式:
COUNTIFS(D3:D50,">35",E3:E50,"是",F3:F50,"是")。
vbafunction函數(shù)的用法
在VBA編程中,自定義函數(shù)可以通過編寫Function過程實現(xiàn)。函數(shù)可以完成很多復(fù)雜的計算,例如求和、平均值、最大值、最小值等。與Excel內(nèi)置函數(shù)類似,自定義函數(shù)可以通過函數(shù)名和參數(shù)來調(diào)用。函數(shù)名和參數(shù)需要在括號內(nèi),參數(shù)之間用逗號隔開。下面是一個簡單的自定義函數(shù)示例:
```
Functionsum(aAsInteger,bAsInteger)AsInteger
sum=a+b
EndFunction
```
上述示例中,定義了一個名為sum的函數(shù),該函數(shù)有兩個參數(shù)a和b,函數(shù)的作用是求兩個數(shù)的和。在調(diào)用該函數(shù)時,需要傳入兩個參數(shù)的值,并將函數(shù)的返回值賦給一個變量。例如:
```
DimresultAsInteger
result=sum(1,2)
```
上述代碼中,調(diào)用了sum函數(shù),并將1和2作為參數(shù)傳入,將函數(shù)的返回值賦給result變量。
自定義函數(shù)的代碼可以保存在模塊中,可以在該模塊中編寫多個自定義函數(shù)。在調(diào)用自定義函數(shù)時,需要在代碼中引用該函數(shù)所在的模塊。如果需要在所有工作簿中運行自定義函數(shù),可以將自定義函數(shù)代碼保存為加載宏,并將該宏保持運用。
vba條件函數(shù)有哪些
用VBA應(yīng)該都是用方法的吧?函數(shù)基本是在EXCEL本身用的。VBA的選擇有以下兩種: IF本身只有兩種選擇,如果是真則1,是假則2,若要實現(xiàn)第三種選擇,必須要嵌套。 多分支選擇一般都選用SelectCase。如果是三種的話,兩種方法都差不多,都可以考慮。
關(guān)于本次vba函數(shù)參考手冊和vba do while循環(huán)語句舉例的問題分享到這里就結(jié)束了,如果解決了您的問題,我們非常高興。
本文鏈接:http:///qianduan/2709.html