{{ transformations:SearchFilterAction.png}}
====== FILTER BY SEARCH ======
Category: Transform / Filters\\
\\
=====Description=====
This action keeps or removes rows where values in a specified column contain a particular substring or match a regular expression.\\
\\
=====Use cases=====
*Create subsets of a dataset based on parts of values in a specific column (literal strings or regular expressions).
*Clean a dataset by removing records that may have "junk" data in a specific column.
\\
=====Action settings=====
^Setting ^Description ^
|Column|Select the column containing the values to be used for filtering. |
|Search type|Select what part of the values should match the search string. See the table below.|
|Search string*|Enter the string or regular expression to match in the selected column's values. If "Regular expression" is selected\\ as the //Search type//, this setting changes to "Regular expression".|
|Regular expression|This setting appears when "Regular expression" is selected as the //Search type//. Enter the regular expression to\\ be evaluated against all values in the selected column. See [[https://en.wikipedia.org/wiki/Regular_expression|regular expression]] for more information.|
|Case sensitive|When checked, the case will not be considered when matching the search string.|
|Filter mode|Select whether rows with matching values will be kept in the dataset, or removed. Options: //Keep only \\ matching values// or //Remove matching values//.|
* Setting can be specified using a [[:parameters|parameter]].
\\
=====Remarks=====
In cases where no values match the search string:
* If //Keep only matching values// was selected, the result will be an empty dataset.
* If //Remove matching rows// was selected, the result will be the full dataset (no rows removed).
\\
=====Examples=====
====Example #1====
>Find all rivers that start with 'Y'.\\
===Before (source table)===
^River ^Length (km) ^Continent ^
| Nile | 6650| Africa |
| Amazon | 6400| South America |
| Yangtze | 6300| Asia |
| Mississippi | 6275| North America |
| Yenisei | 5539| Asia |
| Yellow River | 5464| Asia |
| Ob | 5410| Asia |
| ParanĂ¡ | 4880| South America |
===After (result table)===
^ River ^ Length (km) ^ Continent ^
| **Yangtze** | **6300**| **Asia** |
| **Yenisei** | **5539**| **Asia** |
| **Yellow River** | **5464**| **Asia** |
===Action parameters===
> Column: River
> Search type: Starts with
> Search string: "Y"
\\
====Example #2====
>Find the phone numbers using the "(###) ###-####' format.
===Before (source table)===
^ phone_nums ^
|111-222-3333 |
|(555) 555-5555 |
|+1 777-888-9999 |
|444 555 6666 |
|(123) 456-7890 |
===After (result table)===
^ phone_nums ^
|**(555) 555-5555** |
|**(123) 456-7890** |
===Action parameters===
> Column: phone_nums
> Search type: Regular expression
> Regular expression: "^\(\d{3}\)\s\d{3}-\d{4}$"
> Keep only matching values
\\
=====Community examples=====
* [[https://community.easymorph.com/t//1475/1|Finding all projects with particular action]] ([[https://community.easymorph.com/uploads/short-url/cM8AssOT6zQXD8JDr9adUAy2sDM.morph|Project]]; Module: //Main//; Group: //Tab 1//; Table: //Table 2//; Action position: //3//)
* [[https://community.easymorph.com/t//1800/4|Download multiple files from HTTPS and copy to folder, preserving file names]] ([[https://community.easymorph.com/uploads/short-url/pQyGPi01bpxaWBHR6LdGlGMyRbH.morph|Project]]; Module: //Main//; Group: //Tab 1//; Table: //Table 1//; Action position: //3//)
* [[https://community.easymorph.com/t//2051/1|How to search a text file (e.g. task log) and see result in Server Pages]] ([[https://community.easymorph.com/uploads/short-url/7ZHCVj2p6RV5j6paCUZCnho29vK.morph|Project]]; Module: //Main//; Group: //Tab 1//; Table: //Table 1//;\\ Action position: //2//)
\\
=====See also=====
* [[transformations:selectionfilter|Filter]]
* [[transformations:filter|Filter by condition]]
* [[transformations:filterbytype|Filter by type]]
* [[transformations:regexp|Regular expression]]