How to Filter a Map Based on Keys in TypeScript - Step by Step Examples



How to Filter a Map Based on Keys in TypeScript ?

Answer

To filter a map based on keys in TypeScript, you can iterate over the map and add key-value pairs that meet the filter criteria to a new map. This method allows you to create a subset of the original map based on specific key conditions.



✐ Examples

1 Filtering a Map Based on Key Range

We can filter a map based on a range of keys in TypeScript by iterating over the map and adding key-value pairs that fall within the specified range to a new map.

For example,

  1. We start by declaring and initializing a map named myMap with some key-value pairs. In this example, the map has integer keys and string values.
  2. We declare an empty map named filteredMap to store the filtered key-value pairs.
  3. We define the lower and upper bounds of the key range.
  4. We iterate over the original map using the forEach method and check if each key falls within the specified range.
  5. We add the key-value pairs that meet the condition to the filteredMap.
  6. We print the filtered map to the console using the console.log function to verify the filtering.

TypeScript Program

const myMap = new Map<number, string>([
    [1, 'one'],
    [2, 'two'],
    [3, 'three'],
    [4, 'four'],
    [5, 'five']
]);

// Declare an empty map to store the filtered key-value pairs
const filteredMap = new Map<number, string>();

// Define the key range
const lowerBound = 2;
const upperBound = 4;

// Iterate over the original map and filter based on the key range
myMap.forEach((value, key) => {
    if (key >= lowerBound && key <= upperBound) {
        filteredMap.set(key, value);
    }
});

// Print the filtered map
console.log('Filtered Map by Key Range:', Array.from(filteredMap));

Output

Filtered Map by Key Range: [[2, 'two'], [3, 'three'], [4, 'four']]

2 Filtering a Map Based on Specific Keys

We can filter a map based on specific keys in TypeScript by iterating over the map and adding key-value pairs that match the specified keys to a new map.

For example,

  1. We start by declaring and initializing a map named myMap with some key-value pairs. In this example, the map has integer keys and string values.
  2. We declare an empty map named filteredMap to store the filtered key-value pairs.
  3. We define a set of specific keys that we want to filter the map by.
  4. We iterate over the original map using the forEach method and check if each key matches one of the specified keys.
  5. We add the key-value pairs that meet the condition to the filteredMap.
  6. We print the filtered map to the console using the console.log function to verify the filtering.

TypeScript Program

const myMap = new Map<number, string>([
    [1, 'one'],
    [2, 'two'],
    [3, 'three'],
    [4, 'four'],
    [5, 'five']
]);

// Declare an empty map to store the filtered key-value pairs
const filteredMap = new Map<number, string>();

// Define the specific keys to filter by
const keysToFilter = new Set([1, 3, 5]);

// Iterate over the original map and filter based on the specific keys
myMap.forEach((value, key) => {
    if (keysToFilter.has(key)) {
        filteredMap.set(key, value);
    }
});

// Print the filtered map
console.log('Filtered Map by Specific Keys:', Array.from(filteredMap));

Output

Filtered Map by Specific Keys: [[1, 'one'], [3, 'three'], [5, 'five']]

3 Filtering a Map with String Keys Based on Prefix

We can filter a map with string keys based on a specific prefix in TypeScript by iterating over the map and adding key-value pairs that have keys starting with the given prefix to a new map.

For example,

  1. We start by declaring and initializing a map named myMap with some key-value pairs. In this example, the map has string keys and string values.
  2. We declare an empty map named filteredMap to store the filtered key-value pairs.
  3. We define a prefix string that we want to filter the map by.
  4. We iterate over the original map using the forEach method and check if each key starts with the specified prefix.
  5. We add the key-value pairs that meet the condition to the filteredMap.
  6. We print the filtered map to the console using the console.log function to verify the filtering.

TypeScript Program

const myMap = new Map<string, string>([
    ['apple', 'fruit'],
    ['banana', 'fruit'],
    ['carrot', 'vegetable'],
    ['apricot', 'fruit'],
    ['blueberry', 'fruit']
]);

// Declare an empty map to store the filtered key-value pairs
const filteredMap = new Map<string, string>();

// Define the prefix to filter by
const prefix = 'ap';

// Iterate over the original map and filter based on the prefix
myMap.forEach((value, key) => {
    if (key.startsWith(prefix)) {
        filteredMap.set(key, value);
    }
});

// Print the filtered map
console.log('Filtered Map by Prefix:', Array.from(filteredMap));

Output

Filtered Map by Prefix: [['apple', 'fruit'], ['apricot', 'fruit']]

Summary

In this tutorial, we learned How to Filter a Map Based on Keys in TypeScript language with well detailed examples.




More TypeScript Maps Tutorials

  1. How to create an Empty Map in TypeScript ?
  2. How to create a Map with Initial Key-Value Pairs in TypeScript ?
  3. How to Print a Map in TypeScript ?
  4. How to Add a Key-Value Pair to a Map in TypeScript ?
  5. How to Set a Default Value for a Key in a Map in TypeScript ?
  6. How to Update the Value for a Key in a Map in TypeScript ?
  7. How to Check if a Map is Empty in TypeScript ?
  8. How to Check if a Key Exists in a Map in TypeScript ?
  9. How to Check if a Value Exists in a Map in TypeScript ?
  10. How to Get the Value Associated with a Key in a Map in TypeScript ?
  11. How to Remove a Key-Value Pair from a Map in TypeScript ?
  12. How to Remove Key-Value Pairs from a Map Based on Values in TypeScript ?
  13. How to Clear All Key-Value Pairs from a Map in TypeScript ?
  14. How to Iterate Over Keys in a Map in TypeScript ?
  15. How to Iterate Over Values in a Map in TypeScript ?
  16. How to Iterate Over Entries (Key-Value Pairs) in a Map in TypeScript ?
  17. How to Get the Size (Number of Key-Value Pairs) of a Map in TypeScript ?
  18. How to Convert a Map to an Array of Keys in TypeScript ?
  19. How to Convert a Map to an Array of Values in TypeScript ?
  20. How to Convert a Map to an Array of Key-Value Pairs in TypeScript ?
  21. How to Merge Two Maps in TypeScript ?
  22. How to Copy a Map in TypeScript ?
  23. How to Check if Two Maps are Equal in TypeScript ?
  24. How to Sort a Map by Keys in TypeScript ?
  25. How to Sort a Map by Values in TypeScript ?
  26. How to Filter a Map Based on Keys in TypeScript ?
  27. How to Filter a Map Based on Values in TypeScript ?
  28. How to Reduce Values in a Map to a Single Value in TypeScript ?
  29. How to Convert an Array of Key-Value Pairs to a Map in TypeScript ?
  30. How to Convert a Map to a JSON String in TypeScript ?
  31. How to Convert a JSON String to a Map in TypeScript ?
  32. How to Swap Keys and Values in a Map in TypeScript ?
  33. How to Create a Map of Maps in TypeScript ?
  34. How to Iterate Over a Map of Maps in TypeScript ?