Tools for generating regular expressions
Conclusions
Deriving regular expressions based on existing text fragments and patterns helps to analyze and recognize similarities in more complex patterns. The tools I tested work well but not always without error. Some tools generated regular expressions that were more generic than they actually should be based on the text fragments, resulting in searches that returned more matches than desired. In particular, these tools may include results that don't actually match the search patterns, resulting in false positives and some fuzziness.
Regular expressions are complex, inherently mapping a fragment and pattern differently. The performance of these tools does deserve credit given the complexity of the tasks. For these generators to be more useful in the future, increased precision would be desirable.
Acknowledgement
The author would like to thank Axel Beckert and Arne Wichmann for their help and critical comments during the preparation of this article.
Infos
- Regular expression: https://en.wikipedia.org/wiki/Regular_expression
- grep everything: http://noone.org/blog/English/Computer/Shell/grep%20everything.futile
- xmlgrep: https://linux.die.net/man/1/xmlgrep
- "Search more efficiently with Ugrep" by Karsten G¸nther, Linux Magazine, issue 245, April 2021, https://www.linux-magazine.com/Issues/2021/245/Tracked-Down/(language)/eng-US
- Regular-Expressions.info: http://www.regular-expressions.info/
- Regex DB: https://rgxdb.com/
- Friedly, Jeffrey. Mastering Regular Expressions, O'Reilly Media, Inc., 2006: http://regex.info/book.html
- RegEx101: https://regex101.com/
- txt2re: http://www.txt2re.com/index_php3.html
- grex: https://github.com/pemistahl/grex
- regexgen: https://github.com/devongovett/regexgen
- Regex Generator by Olaf Neumann: https://regex-generator.olafneumann.org/
- rgxg: https://rgxg.github.io/
- txt2regex: https://aurelio.net/projects/txt2regex/
- Fink: https://www.finkproject.org/
- RegexGenerator: https://github.com/dbuhlbrown/Regex-Generator
- regex-generator-lib (Python): https://pypi.org/project/regex-generator-lib/
- tdda: http://www.tdda.info/
- RegExTractor: https://github.com/iuliux/RegExTractor
« Previous 1 2 3
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you've found an article to be beneficial.
News
-
elementary OS 7.1 Now Available for Download
The team behind elementary OS has released the latest version of its operating system with a focus on personalization, inclusivity, accessibility, and privacy.
-
The GNU Project Celebrates Its 40th Birthday
September 27 marks the 40th anniversary of the GNU Project, and it was celebrated with a hacker meeting in Biel/Bienne, Switzerland.
-
Linux Kernel Reducing Long-Term Support
LTS support for the Linux kernel is about to undergo some serious changes that will have a considerable impact on the future.
-
Fedora 39 Beta Now Available for Testing
For fans and users of Fedora Linux, the first beta of release 39 is now available, which is a minor upgrade but does include GNOME 45.
-
Fedora Linux 40 to Drop X11 for KDE Plasma
When Fedora 40 arrives in 2024, there will be a few big changes coming, especially for the KDE Plasma option.
-
Real-Time Ubuntu Available in AWS Marketplace
Anyone looking for a Linux distribution for real-time processing could do a whole lot worse than Real-Time Ubuntu.
-
KSMBD Finally Reaches a Stable State
For those who've been looking forward to the first release of KSMBD, after two years it's no longer considered experimental.
-
Nitrux 3.0.0 Has Been Released
The latest version of Nitrux brings plenty of innovation and fresh apps to the table.
-
Linux From Scratch 12.0 Now Available
If you're looking to roll your own Linux distribution, the latest version of Linux From Scratch is now available with plenty of updates.
-
Linux Kernel 6.5 Has Been Released
The newest Linux kernel, version 6.5, now includes initial support for two very exciting features.