Mafunzo haya yataeleza Mpangilio wa VBA, aina mbalimbali za safu, safu mbadala, na mbinu za safu kwa usaidizi wa mifano ya upangaji:
Kibadala cha kawaida cha VBA ni kishikilia mahali ambacho huhifadhi thamani ya data moja. Ina uhusiano wa 1 hadi 1 yaani tofauti 1 kwa thamani 1.
Sasa fikiria kuhifadhi thamani nyingi ambazo ni za aina moja. Badala ya kuunda anuwai nyingi, unaweza kuunda tofauti moja na kuhifadhi aina zote za maadili. Tofauti hii inaitwa ARRAY.
Katika somo hili, utapata kujua ni safu gani za VBA, zenye sura moja, na zenye pande mbili pamoja na aina tofauti za safu kama vile Zisizohamishika na Zinazobadilika. Pia tutaelewa mbinu mbalimbali za safu zinazotumika katika VBA.
Mkusanyiko wa VBA
Mkusanyiko ni aina maalum ya utofauti unaoweza kuhifadhi thamani nyingi za aina sawa ya data. .
Kwa mfano, ikiwa una majina ya wafanyakazi 100, basi badala ya kuunda vigeu 100 vya mfuatano wa aina ya data, unaweza tu kuunda safu moja ya kutofautisha ya mfuatano wa aina na kugawa thamani 100. kwa muundo sawa wa safu.
Safu ya Dimensional Moja
Safu ambayo ina vipengele vyote katika safu mlalo moja au katika safu moja inaitwa safu ya mwelekeo mmoja. Kuorodhesha majina ya wanafunzi wote darasani katika safu wima moja ni mfano wa safu yenye mwelekeo mmoja. Inatangazwa kama inavyoonyeshwasafu imetangazwa kama inavyoonyeshwa hapa chini.
Dim ArrayName(FirstIndex Kwa LastIndex, FirstIndex Kwa LastIndex) Kama DataType.
Mfano: Alama za Dim(1 Hadi 3) , 0 Hadi 2) Kama Nambari
Q #3) Jinsi ya kubadilisha Masafa kuwa Mpangilio?
Jibu: Tunaweza kutumia kitendakazi cha Transpose kubadilisha masafa kuwa safu. Msimbo huu utaunda Mys[10]
Sub Example() Dim Mys As Variant Mys = Application.Transpose(Range("A1:A10")) End Sub
Q #4) Lahaja ya safu katika VBA ni ipi?
Jibu: Safu ya kibadala itakubali aina zote za data kwa faharasa yake yaani unaweza kuhifadhi aina tofauti za thamani katika safu moja.
Mfano:
Dim arrayData(3) Kama Lahaja
arrayData(0) = “Vikas Vipal”
arrayData(1) = 411234567890#
Njia za kubadilisha ukubwa wa safu wakati wa Runtime na pia kuhifadhi maadili kwa kutumia redim reserve zilijadiliwa kwa mifano. Hatimaye, tulijifunza mbinu za Array ambazo zitatusaidia katika kufanya shughuli kadhaa.
hapa chini.Dim arrayname(Lowerbound Kwa UpperBound) Kama DataType
Kuna njia nyingi za kutangaza safu. Ifuatayo ni mifano michache.
Mfano:
#1) Dim MyArrayExample(0 Hadi 3) As Integer
Huunda safu iliyo na eneo 0,1,2,3 litakalokubali thamani Nambari kamili.
#2) Dim MyArray2(3) Kama Mfuatano
Chaguomsingi kutoka 0 hadi 3 na kuunda safu iliyo na eneo 0,1,2,3 ambayo itakubali thamani za Mfuatano.
#3) Dim MyArray2(13 hadi 15) Kama Mbili
Huunda safu kuanzia 13 yaani 13, 14, na 15, na inakubali Thamani Maradufu. Tumetaja kikomo cha chini kuwa 13, kwa hivyo safu itaanza kugawa thamani kutoka eneo la 13 badala ya 0.
Hebu tuunde msimbo rahisi na tuelewe njia zote 3 za utangazaji wa safu.
Kumbuka: Kuandika Msimbo wa VB Fungua Microsoft Excel (matoleo yanayotumika ni Excel 2007, 2010, 2013, 2016, 2019). Nenda kwenye Kichupo cha Msanidi Programu -> Visual Basic (Vinginevyo tumia njia ya mkato Alt+F11). Katika kihariri cha VB, bofya kwenye Ingiza -> Moduli na ubandike msimbo ulio hapa chini.
Zingatia utaratibu ulio hapa chini unaoonyesha aina tofauti za matamko.
Private Sub arrayExample1() Dim firstQuarter(0 To 2) As String ‘creates array with index 0,1,2 firstQuarter(0) = "Jan" firstQuarter(1) = "Feb" firstQuarter(2) = "Mar" MsgBox "First Quarter in calendar " & " " & firstQuarter(0) & " " & firstQuarter(1) & " " & firstQuarter(2) End Sub Private Sub arrayExample2() Dim secondQuarter(2) As String ‘creates array with index 0,1,2 secondQuarter(0) = "April" secondQuarter(1) = "May" secondQuarter(2) = "June" MsgBox "Second Quarter in calendar " & " " & secondQuarter(0) & " " & secondQuarter(1) & " " & secondQuarter(2) End Sub Private Sub arrayExample3() Dim thirdQuarter(13 To 15) As String ‘creates array with index 13,14,15 thirdQuarter(13) = "July" thirdQuarter(14) = "Aug" thirdQuarter(15) = "Sep" MsgBox "Third Quarter in calendar " & " " & thirdQuarter(13) & " " & thirdQuarter(14) & " " & thirdQuarter(15) End Sub
Gonga F5 au ubonyeze kitufe cha endesha kwenye upau wa vidhibiti. kutekeleza msimbo.
Tofauti ya Kawaida Vs Array Variable
Sasa tunajua jinsi safu ya mwelekeo mmoja inavyofanya kazi. Kwa hivyo hebu tuchukue muda kuelewa kwa nini safu ni muhimu sana ndanilugha za programu.
Chukulia kuwa unahitaji kuingiza mshahara wa wafanyikazi 5. Ili kufanikisha hili kwa kutumia kigezo cha kawaida, unahitaji kuunda vigeu 5.
Public Sub RegularVariable() Dim shet As Worksheet Set shet = ThisWorkbook.Worksheets("Sheet1") ' Declare variable for each student Dim Emp1 As String Dim Emp2 As String Dim Emp3 As String Dim Emp4 As String Dim Emp5 As String ' Read student marks from cell Emp1 = shet.Range("A" & 2).Value Emp2 = shet.Range("A" & 3).Value Emp3 = shet.Range("A" & 4).Value Emp4 = shet.Range("A" & 5).Value Emp5 = shet.Range("A" & 6).Value ' Print student marks Debug.Print "Emp Name" Debug.Print Emp1 Debug.Print Emp2 Debug.Print Emp3 Debug.Print Emp4 Debug.Print Emp5 End Sub
Sasa hebu tuunde msimbo sawa kwa kutumia muundo wa Array.
Option Explicit Public Sub ArrayVarible() Dim shet As Worksheet Set shet = ThisWorkbook.Worksheets("Sheet1") Dim Employee(1 To 6) As String Dim i As Integer For i = 1 To 6 Employee(i) = shet.Range("A" & i).Value Debug.Print Employee(i) Next i End Sub
Hapa, tumetumia utofauti wa safu moja ambao utahifadhi majina yote ya wafanyikazi. Tuseme unahitaji kuongeza majina 100 zaidi ya wafanyikazi basi unahitaji kubadilisha ukubwa wa safu na sio lazima uunde kigezo kipya.
Hii itapunguza idadi ya mistari kwenye msimbo na hivyo kuifanya iwe rahisi. inaeleweka na inasomeka.
Safu ya Milalo Mbili
Safu ya 2-dimensional ina faharasa 2 - faharasa ya kwanza itawakilisha safu na faharasa ya 2 itawakilisha safu. Ina safu mlalo na safu wima nyingi na kwa kawaida huwakilishwa katika umbizo la jedwali.
Tamko la safu 2 hafifu ni kama ifuatavyo:
Dim ArrayName(FirstIndex Hadi LastIndex, FirstIndex To LastIndex) Kama DataType.
Fikiria mfano wa kuhifadhi alama za wanafunzi 2 waliopatikana katika masomo 3. Kwa hivyo tutaunda safu ya 2-dimensional ambayo inachukua safu 2 na safu wima 3.
Tutaanzisha safu kutoka safu ya 1 hadi safu ya 2 na safu ya 1 hadi safu wima ya 3.
Sub Twodim() Dim totalMarks(1 To 2, 1 To 3) As Integer totalMarks(1, 1) = 23 totalMarks(2, 1) = 34 totalMarks(1, 2) = 33 totalMarks(2, 2) = 55 totalMarks(1, 3) = 45 totalMarks(2, 3) = 44 Msgbox “Total Marks in Row 2 and column 2 is “ &totalMarks(2,2) Msgbox “Total Marks in Row 1 and column 3 is “ &totalMarks(1,3) End Sub
Gonga F5. au Bonyeza kitufe cha endesha kwenye upau wa vidhibiti ili kutekeleza msimbo.
Safu mlalo ya 2 na Safu wima 2
Safu mlalo ya 1 na Safu Wima 3
Safu Zisizohamishika
Safu zisizohamishika pia huitwa StaticMkusanyiko una mshikamano wa chini na wa juu uliowekwa na saizi hii haiwezi kubadilishwa wakati wa kukimbia. Saizi ya safu imebainishwa wakati wa tamko ndani ya mabano. Mifano yote hapo juu ni Safu zisizohamishika kama tulivyotaja ukubwa wake wakati wa tamko.
Safu zisizohamishika hutumiwa kwa kawaida ukiwa na uhakika kuhusu ukubwa wa safu. Kwa mfano, idadi ya siku katika wiki, unaweza kuunda safu iliyo na alama ya chini ya 0 na ya juu ya 6 na uhakikishe kuwa hutawahi kubadilisha ukubwa wake.
Misururu Yenye Nguvu 10>
Mikusanyiko Inayobadilika huturuhusu kubadilisha ukubwa wa safu wakati wa utekelezaji. Hizi ni muhimu wakati huna uhakika kuhusu ukubwa wa safu. Tuseme katika udahili wa chuo kikuu, huenda huna uhakika ni wanafunzi wangapi watapata nafasi ya kujiunga, kwa hivyo huwezi kubainisha ukubwa katika muundo au wakati wa kutangaza.
Tamko la safu Inayobadilika ni sawa na Tuli. safu yenye mabano tupu.
Dim Employee() As String
REDIM
Tunapotaka kubadilisha ukubwa tunahitaji kutumia REDIM , tunahitaji kutambua kwamba mpaka wa chini hauwezi kubadilishwa, tunaweza tu kubadilisha mpaka wa juu wa safu.
Sub dynamicArray() Dim dynArray() As String Dim curdate As Date curdate = Now ReDim dynArray(2) ‘ Redim will help to change the array size during runtime dynArray(0) = "John" dynArray(1) = "Tom" dynArray(2) = "Tonny" MsgBox "Students Enrolled after " & curdate & " are “ & dynArray(0) & ", " & dynArray(1) & ", " & dynArray(2) End Sub
Sasa, tunajua tunaweza badilisha saizi ya safu wakati wa utekelezaji, kwa hivyo tunaweza kutumia taarifa ya ReDim wakati wowote tunapohitaji kuongeza ubounding wa safu. Hebu jaribu Kuongeza ukubwa wa safu mara moja zaidi na kuongeza mpyajina la mwanafunzi.
Sub RedimExample() Dim dynArray() As String Dim curdate As Date curdate = Now Dim size As Integer ReDim dynArray(2) dynArray(0) = "John" dynArray(1) = "Tom" dynArray(2) = "Tonny" MsgBox "Students Enrolled untill " & curdate & " are " & dynArray(0) & ", " & dynArray(1) & ", " & dynArray(2) ReDim dynArray(3) ‘ Redim will reinitialise the array and destroy the old values dynArray(3) = "John" MsgBox "Students Enrolled untill " & curdate & " are " & dynArray(0) & ", " & dynArray(1) & ", " & dynArray(2) & " , " & dynArray(3) End Sub
Ungeona kuwa matokeo hayakuonyesha majina ya wanafunzi yaliyoongezwa hapo awali, yanatoa thamani isiyo na maana. Hiyo ni kwa sababu taarifa ya Redim itaunda safu mpya yenye ukubwa mpya na kuharibu thamani za zamani.
ReDim Preserve
Taarifa ya Hifadhi hutusaidia katika kushinda kizuizi cha ReDim kwa kuhifadhi thamani za zamani. na hivyo kuongeza ukubwa wa safu.
Hebu tuandike upya msimbo ulio hapo juu kwa kutumia ReDim Preserve.
Sub preserveExample() Dim dynArray() As String Dim curdate As Date curdate = Now Dim size As Integer ReDim dynArray(2) dynArray(0) = "John" dynArray(1) = "Tom" dynArray(2) = "Tonny" MsgBox "Students Enrolled untill " & curdate & " are " & dynArray(0) & ", " & dynArray(1) & ", " & dynArray(2) ReDim preserve dynArray(3) ‘ Redim preserve will retain the old values dynArray(3) = "John" MsgBox "Students Enrolled untill " & curdate & " are " & dynArray(0) & ", " & dynArray(1) & ", " & dynArray(2) & " , " & dynArray(3) End Sub
Kama tulivyotumia kuhifadhi nenomsingi, thamani zilizoingizwa hapo awali hazijapotea na thamani mpya huongezwa kwa ufanisi.
Mkusanyiko wa Lahaja
Mpaka sasa tumeona safu inayokubali aina sawa za thamani. Sasa hebu tutangaze safu kama kibadala na tuhifadhi aina mbalimbali za data kama vile Kamba, Tarehe, Muda Mrefu, Nambari kamili katika safu moja.
Mfano:
Sub arrayVariant() Dim arrayData(3) As Variant arrayData(0) = "Vikram Vikrant" arrayData(1) = 411234567890# arrayData(2) = 38 arrayData(3) = "06-09-1972" MsgBox "Details of person " & arrayData(0) & " is " & " Phone No " & arrayData(1) & " ,Id " & arrayData(2) & " ,DOB " & arrayData(3) End Sub
Mbinu za Mpangilio wa VBA
Kuna mbinu kadhaa katika safu za VBA ambazo zitatusaidia kutekeleza utendakazi tofauti, kama ilivyotajwa hapa chini.
Sl. No | Jina | Sintaksi | Maelezo |
---|---|---|---|
1 | Array | Array(arglist) | Hubadilisha kibadala cha kawaida kigeugeu kuwa Mkusanyiko. |
2 | Futa | Futa jina la safu | Inatumika kuweka upya safu ya ukubwa uliowekwa na kuachilia kumbukumbu kwa Dynamicsafu. |
3 | IsArray | IsArray (jina la kubadilika) | Huamua kama utofauti ni safu. |
4 | Mpaka | LBound( ArrayName, [Dimension] ) | Hurejesha usajili wa chini kabisa wa safu. |
5 | Ubound | UBound( ArrayName , [Dimension] ) | Hurejesha usajili wa juu zaidi wa safu. |
6 | Gawanya | Gawanya(maneno, [ delimiter, [ limit, [ compare ]]]) | Inagawanya mfuatano katika mifuatano midogo mingi na kurudisha safu msingi sifuri. |
7 | Jiunge | Jiunge(sourcearray, [ delimiter ]) | Hujiunga na mifuatano midogo mingi katika safu na kurejesha thamani ya mfuatano . |
8 | Chuja | Chuja(chanzo, linganisha, [ jumuisha, [ linganisha ]]) | Kichujio kitaturuhusu kutafuta ulinganifu uliobainishwa kutoka kwa safu. |
Hebu tujadili kila moja yao kwa undani kwa mfano.
#1) Mkusanyiko
Hebu tutangaze kibadala cha kawaida na tukitumie kama mkusanyiko. Unapotaka kubadilisha lahaja ya kawaida kuwa safu, tunahitaji kutumia KULIMBILIA kama inavyoonyeshwa kwenye mfano ulio hapa chini.
Vitendo vya kukokotoa vya mkusanyiko hukubali hoja ambayo ina thamani zilizotenganishwa kwa koma. . Thamani hizi zimetolewa kama kipengele cha safu.
Sub variantArray() Dim varData As Variant varData = Array("Mon Bel", "+61 112334123", 567, "06-09-1972") MsgBox "Details of person " & varData(0) & " is " & " Phone No " & varData(1) & " ,Id " & varData(2) & " ,DOB " & varData(3) End Sub
Lazima utambue kigezo cha safu kwa kutumia faharasa,kwa hivyo katika mfano ulio hapo juu, thamani hutolewa kama varData(0) varData(2) varData(3).
#2) Futa
Chaguo hili la kukokotoa litafuta thamani zote zilizowekwa kwa a. safu ya saizi isiyobadilika na itafungua nafasi ya kumbukumbu kwa safu inayobadilika.
Sintaksia: Futa jina la mkusanyiko
Futa ina tabia tofauti kwa aina tofauti za data kama ilivyotolewa. hapa chini.
- Kwa nambari isiyobadilika: Thamani zote zimewekwa upya hadi sifuri.
- Kwa aina ya data ya mfuatano usiobadilika: Thamani zote zimewekwa upya hadi urefu wa sifuri.
- Kwa safu inayobadilika: Huweka huru hifadhi inayotumiwa na safu.
Mfano :
Sub eraseExample() Dim NumArray(3) As Integer Dim decArray(2) As Double Dim strArray(2) As String NumArray(0) = 12345 decArray(1) = 34.5 strArray(1) = "Erase Function" Dim DynaArray() ReDim DynaArray(3) MsgBox " Values before Erase " & (NumArray(0)) & "," & (decArray(1)) & " , " & (strArray(1)) Erase NumArray Erase decArray Erase strArray Erase DynaArray ' Free the memory ' All values are erased. MsgBox " Values after Erase " & NumArray(0) & "," & decArray(1) & " , " & strArray(1) End Sub
Tokea kabla ya kutumia kipengele cha Kufuta
Matokeo baada ya kutumia Futa
#3) IsArray
Chaguo hili la kukokotoa linatumika kubainisha ikiwa kigezo cha ingizo kilichotolewa ni mkusanyiko au la. Inarejesha kweli ikiwa kigezo kilichowekwa ni kweli, vinginevyo kitarejesha sivyo.
Sintaksia : IsArray (jina la kubadilika)
Mfano:
Sub isArrayTest() Dim arr1, arr2 As Variant arr1 = Array("Jan", "Feb", "Mar") arr2 = "12345" MsgBox ("Is arr1 an Array : " & IsArray(arr1)) MsgBox ("Is arr2 an Array : " & IsArray(arr2)) End
matokeo kutoka kwa Msgbox ya kwanza
matokeo kutoka kwa kisanduku cha pili cha msg
38>
#4) Lbound
Hurejesha hati iliyo chini kabisa ya safu iliyobainishwa kama hoja ya chaguo za kukokotoa za Lbound.
Sintaksia: LBound( ArrayName, [Dimension] )
ArrayName ni jina la safu.
Kipimo ni thamani kamili ya hiari, ikiwa safu ina vipimo vingi, basi unaweza kubainisha kwani kipimo gani unataka kubainisha Lbound.
Mfano:
Sub lboundTest() Dim Result1, Result2, Result3 Dim ArrayValue(1 To 10, 5 To 15, 10 To 20) ' Declare array variables. Dim Arraywithoutlbound(10) Result1 = LBound(ArrayValue, 1) ' Returns 1. Result2 = LBound(ArrayValue, 3) ' Returns 10. Result3 = LBound(Arraywithoutlbound) MsgBox "Lowest subscript in first array " & Result1 & " lowest subscript in 3rd array " & Result2 & " Lowest subscript in Arraywithoutlbound " & Result3 End Sub
#5) Ubound
It hurejesha hati ya juu ya safu iliyobainishwa kama hoja katika chaguo za kukokotoa Ubound.
Sintaksia: UBUound( ArrayName, [Dimension] )
ArrayName ni jina la safu.
Kipimo ni thamani kamili ya hiari, ikiwa safu ina vipimo vingi, basi unaweza kubainisha ni kipimo gani unataka kubainisha Ubound.
Mfano:
Sub UboundTest() Dim Result1, Result2, Result3 Dim ArrayValue(1 To 10, 5 To 15, 10 To 20) ' Declare array variables. Dim ArraywithoutUbound(10) Result1 = UBound(ArrayValue, 1) Result2 = UBound(ArrayValue, 3) Result3 = UBound(ArraywithoutUbound) MsgBox "Lowest subscript in first array " & Result1 & " lowest subscript in 3rd array " & Result2 & " Lowest subscript in Arraywithoutlbound " & Result3 End Sub
#6) Gawanya
Inarejesha safu yenye idadi ya mistari midogo inayotokana na mfuatano mzima uliotolewa.
1>Sintaksia: Mgawanyiko(maneno, [ delimiter, [ limit, [ compare ]]])
- Maelezo: Huu ndio mfuatano wote utakaotumiwa toa masharti madogo.
- Delimiter: Kwa kutumia kikomo kilichobainishwa, masharti madogo yatatolewa. Ikiwa hili halijatajwa basi nafasi inachukuliwa kuwa kikomo.
- Kikomo: Idadi ya mifuatano midogo itakayorejeshwa.
- Linganisha: Baada ya substring inatolewa, unaweza kutumia chaguo tofauti za kulinganisha ili kujaribu matokeo.
Mfano: Katika mfano ulio hapa chini, tunatumia delimiter kama - na kikomo kama 3.
Kwa hivyo kipengele cha kukokotoa cha mgawanyiko kitatenganisha mfuatano mzima kuwa mfuatano mdogo kulingana na kikomo. Lakini pia tumetaja kikomo kama 3 kwa hivyo masharti madogo hayataundwa baada ya kikomo cha 3. Kwa hivyo kikomo cha mwisho -itarukwa.
Sub splitExample() Dim MyString As String Dim Result() As String Dim DisplayText As String MyString = "This is the example for-VBA-Split-Function" Result = Split(MyString, "-",3) MsgBox Result(0) & vbNewLine & Result(1) & vbNewLine & Result(2) & vbNewLine & Result(3) End Sub
#7) Jiunge
3>Sintaksia: Jiunge(sourcearray, [ delimiter ])
Chanzo: Msururu wa nyuzi zenye mwelekeo mmoja ambao ungependa kuunganishwa kuwa moja.
Delimiter: Kikomo kilichobainishwa kitaongezwa baada ya kila mfuatano wakati wa kujiunga.
Mfano:
Sub joinExample() Dim Result As String Dim dirarray(0 To 2) As String dirarray(0) = "D:" dirarray(1) = "SoftwareTestingHelp" dirarray(2) = "Arrays" Result = Join(dirarray, "\") MsgBox "Date after joining " & Result End Sub
Thamani zote 3 ni imeunganishwa na \ inawekwa kati ya kila neno, kama tulivyotaja \ kama kitenganishi.
#8) Kichujio
Kichujio kitaturuhusu kufanya hivyo. tafuta inayolingana maalum kutoka kwa safu. Kulingana na kigezo cha kichujio, kikundi kidogo cha safu mfuatano kitarejeshwa.
Sintaksia: Kichujio(chanzo, mechi, [ jumuisha, [ linganisha ]])
Mfano:
Sub filterExample() Dim Mystring As Variant Mystring = Array("Software Testing", "Testing help", "Software help") filterString = Filter(Mystring, "help") MsgBox "Found " & UBound(Mystring) - LBound(Mystring) + 1 & " words matching the criteria " End Sub
Mfano huu utafuta neno “msaada” katika safu zote za safu kwa kutumia kichungi cha kukokotoa.
Maswali Yanayoulizwa Mara Kwa Mara
Q #1) Jinsi ya kupata urefu wa safu katika VBA?
Jibu: Ili kupata urefu wa safu katika VBA? safu, tunatumia kitendakazi cha Ubound. Chaguo hili la kukokotoa litatupa usajili wa juu wa safu maalum.
Q #2) Jinsi ya kutangaza safu katika VBA?
Jibu: Moja- safu ya mwelekeo imetangazwa kama inavyoonyeshwa hapa chini.
Dim arrayname(Lowerbound Hadi UpperBound) Kama DataType
Mfano: Dim Myarray(0 Hadi 2) Kama Nambari kamili
Mbili-dimensional