EnumerableDeepSearch
Recursively searches enumerable objects and their nested objects for a given object or string.
Installation
Add this line to your application's Gemfile:
gem 'enumerable_deep_search'
And then execute:
$ bundle
Or install it yourself as:
$ gem install enumerable_deep_search
Usage
In practice it's an exploration tool, I recommend using it with Pry and extending objects as needed. You can also include it on a class and all the instances will inherit the functionality.
Personally I've found this the most useful for searching web apis converted from XML and JSON into Ruby objects. Its useful on any large nested data, such as configuration structures dumped from YAML files.
example:
object.extend EnumerableDeepSearch
object.search 'something'
It will return a facimile of the path to the matching object, for hash-like objects it will return a Hash containing the match as well as the opposite pair (either the key or the value), for array-like objects it will return a two element Array where the first element is the index of the match and second element the match itself.
example:
object.search 'something'
#=> {:foo => [1, 'something']}
Ideas? Complaints?
- You could Contribute: https://github.com/acook/enumerable_deep_search/fork
- Or you could Submit an issue: https://github.com/acook/enumerable_deep_search/issues
- Or you could even ping me on Twitter: http://twitter.com/anthony_m_cook
Contributing
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request