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.