全民一起VBA提高篇-第十五回

傳遞Range提升自定義函數(shù) 巧用屬性分辨公式型內(nèi)容

主要內(nèi)容:

一、使用UBound纵刘,LBound邀窃。代替固定行列數(shù)

舉例1:

dim s(5).UBound(s)=5,LBound(s)=0

dim s(2 to 5,3 to 7).UBouund(s,1)=5,UBound(s,2)=7;LBund(s,1)=2

二假哎、結(jié)構(gòu)化程序互相調(diào)用

舉例2:

Sub 結(jié)構(gòu)化函數(shù)調(diào)用()

? ? Dim ws As Worksheet

? ? For Each ws In Worksheets

? ? ? ? ws.Cells(1, 1) = redCount(ws.UsedRange)

? ? Next ws

End Sub

Function redCount(r As Range)

? ? Dim a As Long, r1 As Range

? ? For Each r1 In r

? ? ? ? If r1.Font.Color = vbRed Then

? ? ? ? ? ? a = a + r1.Value? ?

? ? ? ? End If

? ? Next r1

? ? redCount = a

End Function

提示1:定義一個(gè)fuction redCount的子函數(shù)瞬捕,主程序調(diào)用函數(shù)。這樣結(jié)構(gòu)清晰舵抹。

提示2:主程序接收一個(gè)Range類型的變作為參數(shù),然后掃描每一個(gè)單元格惧蛹,將其中紅色數(shù)字匯總返回。

舉例:3

Function mySum(r As Range)

? ? Dim a&, b&, c&, d&

? ? d = 0

? ? For a = r.Row To r.Row + r.Rows.Count - 1

? ? ? ? c = 1

? ? ? ? For b = r.Column To r.Column + r.Columns.Count - 1

? ? ? ? ? ? c = c * Cells(a, b)

? ? ? ? Next b

? ? ? ? d = d + c

? ? Next a

? ? mySum = d

End Function

提示1:用&代替aslong 迅腔,用符號(hào)聲明變量饱岸,見(jiàn)第三回

提示2:求和的變量初始化為0掺出,但求乘積的變量初始化要為1.

三苫费、Range對(duì)象的轉(zhuǎn)化文本屬性

1.Range.hasFormula屬性

當(dāng)該Range為一個(gè)單元格時(shí)百框,若是公式則返回True闲礼,否則返回False

2.Range.Formula屬性

當(dāng)該Range為一個(gè)單元格時(shí),若是公式則返回公式文本铐维,否則與Value屬性一樣柬泽,返回單元格的內(nèi)容。

3.屬性應(yīng)用嫁蛇,僅粘貼格式

舉例4:

Sub 僅粘貼格式()

? ? Dim w As Worksheet, r As Range

? ? ? ? For Each w In Worksheets

? ? ? ? ? ? For Each r In w.UsedRange

? ? ? ? ? ? ? ? r.Value = r.Value

? ? ? ? ? ? Next r

? ? ? ? Next w

舉例5:? ? ?

End Sub

Sub 僅粘貼格式()

? ? Dim w As Worksheet

? ? ? ? For Each w In Worksheets

? ? ? ? ? ? w.UsedRange.Value = w.UsedRange.Value

? ? ? ? Next w

End Sub

提示1:舉例5為舉例4的簡(jiǎn)化版本锨并,該程序可以作為固定的子程序,用來(lái)將最終結(jié)果轉(zhuǎn)化為僅保留數(shù)值或文本睬棚。

提示2:Formula和Value屬性都可以將單元格的內(nèi)容設(shè)置為公式第煮。

cells(2,3).Formula="=25*2"

cells(2,3).Value="'Sheet3'!C2+10"

以上兩個(gè)表達(dá)方式效果相同。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末抑党,一起剝皮案震驚了整個(gè)濱河市包警,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌底靠,老刑警劉巖害晦,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異苛骨,居然都是意外死亡篱瞎,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門痒芝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)俐筋,“玉大人,你說(shuō)我怎么就攤上這事严衬〕握撸” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)粱挡。 經(jīng)常有香客問(wèn)我赠幕,道長(zhǎng),這世上最難降的妖魔是什么询筏? 我笑而不...
    開(kāi)封第一講書人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任榕堰,我火速辦了婚禮,結(jié)果婚禮上嫌套,老公的妹妹穿的比我還像新娘逆屡。我一直安慰自己,他們只是感情好踱讨,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布魏蔗。 她就那樣靜靜地躺著,像睡著了一般痹筛。 火紅的嫁衣襯著肌膚如雪莺治。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 51,365評(píng)論 1 302
  • 那天帚稠,我揣著相機(jī)與錄音谣旁,去河邊找鬼。 笑死滋早,一個(gè)胖子當(dāng)著我的面吹牛蔓挖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播馆衔,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼瘟判,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了角溃?” 一聲冷哼從身側(cè)響起拷获,我...
    開(kāi)封第一講書人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎减细,沒(méi)想到半個(gè)月后匆瓜,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡未蝌,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年驮吱,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片萧吠。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡左冬,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出纸型,到底是詐尸還是另有隱情拇砰,我是刑警寧澤梅忌,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站除破,受9級(jí)特大地震影響牧氮,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜瑰枫,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一踱葛、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧光坝,春花似錦剖毯、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)擂达。三九已至土铺,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間板鬓,已是汗流浹背悲敷。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留俭令,地道東北人后德。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像抄腔,于是被迫代替她去往敵國(guó)和親瓢湃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • pyspark.sql模塊 模塊上下文 Spark SQL和DataFrames的重要類: pyspark.sql...
    mpro閱讀 9,451評(píng)論 0 13
  • 同是藏身文件夾 相逢何必問(wèn)姓名 主要內(nèi)容 一赫蛇、關(guān)于文本編號(hào) 1.正在打開(kāi)的文件绵患,必須有唯一的編號(hào); 2.文件關(guān)閉后...
    凱凱凱王閱讀 626評(píng)論 0 0
  • 表格聯(lián)手二維數(shù)組 批量修改一騎絕塵 主要內(nèi)容: 一悟耘、數(shù)組 1.概念:Dim 數(shù)組名(最大行落蝙,最大列) AS 類型 ...
    凱凱凱王閱讀 658評(píng)論 0 0
  • 1.1 VBA是什么 直到90年代早期,使應(yīng)用程序自動(dòng)化還是充滿挑戰(zhàn)性的領(lǐng)域.對(duì)每個(gè)需要自動(dòng)化的應(yīng)用程序,人們不得...
    浮浮塵塵閱讀 21,745評(píng)論 6 49
  • 一眼看出Range大小 快速定為數(shù)據(jù)末行 主要內(nèi)容: 一、怎樣得到一個(gè)Range在表格中的位置 1.與Rang...
    凱凱凱王閱讀 455評(píng)論 0 0