# coding=utf8
# the above tag defines encoding for this document and is for Python 2.x compatibility
import re
regex = r"(\w+\s*\n*=\s*\n*)\{\n*\s*`((?:[^`](?!(?:\$\{|\n|(?:'[^`]*\"|\"[^`]*'))))*)`\n*\s*\}"
test_str = ("// Match!\n"
"<Component1\n"
" // Using backticks without utilizing their functionalities\n"
" className={`flex justify-center items-center gap-2`}\n"
" description={``}\n"
" content={\n"
" `These backticks are unnecessary`\n"
" }\n"
" // This is a crime, but I did take it into account\n"
" horrendousFormatting\n"
" =\n"
" {`Please never do something like this`}\n"
"/>\n\n"
"// Multiple matches in a single line\n"
"<svg width={`100%`} height={`100%`} />\n\n"
"// Cases where this regex won't match:\n"
"<Component2\n"
" // Non-string property\n"
" disabled={isDisabled}\n"
" // Quotes/Single quotes with unnecessary brackets\n"
" // (I have another regex that's better adapted for this!)\n"
" href={\"https://regex101.com/library/l9MPcQ\"}\n"
" // String templating\n"
" className={`flex items-center justify-center size-5 ${iconColor}`}\n"
" // Escaping BOTH \" AND ' IN THE SAME STRING with backticks\n"
" title={`This string's backticks are \"justified\"`}\n"
" // Escaping line breaks with backticks\n"
" description={\n"
" `String with\n"
" a line break`\n"
" }\n"
" // \"/'/` mismatch\n"
" content={`Yeah this will turn the rest of your file into a string\"}\n"
">\n"
" {icon}\n\n"
" // No match since this is not a property\n"
" {` `}\n\n"
" (Some people do this instead of using )\n"
"</Component2>\n")
subst = "$1\"$2\""
# You can manually specify the number of replacements by changing the 4th argument
result = re.sub(regex, subst, test_str, 0, re.MULTILINE)
if result:
print (result)
# Note: for Python 2.7 compatibility, use ur"" to prefix the regex and u"" to prefix the test string and substitution.
Please keep in mind that these code samples are automatically generated and are not guaranteed to work. If you find any syntax errors, feel free to submit a bug report. For a full regex reference for Python, please visit: https://docs.python.org/3/library/re.html