Czasami pojawiały się pytania o funkcję „oczyszczającą”, która w tekście zostawiałaby wskazane przez nas znaki a pozostałe usuwała. Po tych pytaniach postanowiliśmy umieścić taką funkcję na blogu, aby ułatwić Wam pracę.:)
Przedstawiona poniżej funkcja pozostawia w tekście znaki, które są wskazane w drugim argumencie funkcji. Jako argument możemy podać ciąg znaków i tak np. jeśli wpiszemy poniższą formułę:
=Pozostaw(„Ala ma kota!”; „ma „)
to funkcja usunie wszystkie znaki poza m, a, oraz spacją. Wynikiem działania będzie „Aa ma a”
Function Pozostaw(PrzeszukiwanyTekst As String, Znak As String) As String
'Funkcja pozostawia w tekście znaki, które są podane w drugim argumencie
Dim Z As String
Dim i As Long
Dim NumerZnaku As Long
For i = 1 To Len(PrzeszukiwanyTekst)
NumerZnaku = NumerZnaku + 1
Z = Mid(PrzeszukiwanyTekst, NumerZnaku, 1)
If Not UCase(Znak) Like "*" & UCase(Z) & "*" And Z <> "" Then
PrzeszukiwanyTekst = Replace(PrzeszukiwanyTekst, Z, "")
NumerZnaku = NumerZnaku - 1
End If
Next
Pozostaw = PrzeszukiwanyTekst
End Function
Jeśli nie wiesz jak wkleić powyższą funkcję to zapraszamy do wpisu jak zacząć pierwsze makro.
Wystarczy skopiować i wkleić powyższy kod a już będziemy mogli korzystać z formuły Podstaw.
Inne przykłady wykorzystania funkcji Pozostaw
Funkcja pozostaw może nam się np. przydać jeśli mamy podany serię i numer dowodu, a chcemy je oddzielić.
Przykładowo: ABS123456
Chcemy jednak wyciągnąć tylko cyfry z podanego ciągu. Wystarczy, że wywołamy funkcję
Pozostaw(„ABS123456″;”0123456789”)
Oczywiście jako argumenty funkcji możemy podawać odwołania do komórek.