Функция sub в regex может принимать функцию в качестве аргумента repl.
📄 Из документации:
If repl is a function, it is called for every non-overlapping occurrence of pattern. The function takes a single match object argument, and returns the replacement string.
То есть для каждого совпадения будет вызвана функция для вычисления замены вместо замены на одну и ту же строку для всех совпадений.
Иными словами, для замены разных совпадений на разные строки не потребуется запускать re.sub() много раз для каждой строки замены. Достаточно определить функцию, которая вернёт строку для каждого из совпадений.
Описание слишком запутанное🤔, давайте лучше рассмотрим на простом примере:
Создаем карту замены. То есть какие строки на какие требуется менять.
remap = {
'раз': '1',
'два': '2',
'три': '3',
'четыре': '4',
'пять': '5',
}
Пишем функцию поиска строки для замены. Единственным аргументом будет объект re.Match.
Используя данные этого объекта мы вычисляем замену on-the-fly!
def get_str(match: re.Match):
word = match.group(1)
return remap.get(word.lower()) or word
Пример текста.
text = '''Раз Два Три Четыре Пять
Вместе будем мы считать
Пять Четыре Три Два Раз
Мы считать научим вас
'''
Теперь запускаем re.sub и вместо строки замены (repl) подаём имя функции.
(Данный паттерн ищет отдельные слова в тексте)
>>> print(re.sub(r'(\w+)', get_str, text))
1 2 3 4 5
Вместе будем мы считать
5 4 3 2 1
Мы считать научим вас
Думаю, достаточно наглядно 🤓
#libs#regex
BTS’ “Permission To Dance On Stage - Live” becomes the First Live Album by an Asian Act to enter the Top 10 of the Worldwide Apple Music Album Charts!
CONGRATULATIONS BTS
#CHARTS
•@OUR_7_PRINCES•
“Dynamite” has surpassed 2.1 billion streams on Spotify, BTS's first song to do so!
Congratulations bts 💜
Let's get that 2B for the MV too.
https://youtu.be/gdZLi9oWNZg?si=MK1oUNrKA-X2B0S0
#CHARTS | #SPOTIFY
•@OUR_7_PRINCES•
"Butterfly" by BTS now hits 300 Million streams on Spotify, becoming their 44th song to do so..!
CONGRATULATIONS BTS
#CHARTS | #SPOTIFY
•@OUR_7_PRINCES•
📊| @/BTS_twt's “PERMISSION TO DANCE ON STAGE – LIVE” (14.5M) breaks the record as the BIGGEST DEBUT for a live album in spotify's HISTORY, surpassing Beyonce ‘Homecoming: The Live Album’ (8.5)!
CONGRATULATIONS BTS
RECORD MAKER BTS
BTS GREATEST OF ALL TIME
#CHARTS | #SPOTIFY
•@OUR_7_PRINCES•
🌍| #PTD_ON_THE_STAGE_LIVE album on itunes —
#1. Australia
#1. Austria
#1. Brazil
#1. France
#1. India
#1. Philippines
#1. Spain
— 7 #1 around the world so far!
Apple Music : https://music.apple.com/in/album/permission-to-dance-on-stage-live/1823627665
Spotify link : https://open.spotify.com/album/7xLhqoM0ilHRKUg2irVSDI?si=VaQHZroSQY2V7tdhnz0oeg
#CHARTS | #iTUNES
•@OUR_7_PRINCES•
#go#chart#charts#cncf#helm#kubernetes
Helm is a tool that helps manage applications on Kubernetes. It simplifies deploying and managing apps by using pre-configured packages called Helm Charts. These charts include all the necessary resources for an application, making it easy to install, update, or remove apps with just a few commands. This saves time and reduces errors, as you only need to edit a single file to change settings across different environments. Using Helm boosts productivity and makes deploying complex applications much easier.
https://github.com/helm/helm
#other#awesome#chartjs#charts#integrations#plugins#resources
Chart.js is a flexible JavaScript library for creating interactive charts with extensive customization options. You can use it with popular frameworks like React, Vue, and Angular through dedicated adapters, and extend its functionality with plugins for styling, features, and data handling. The library supports three major versions—v2 (April 2016), v3 (April 2021), and v4 (November 2022)—each with different plugin compatibility. This means you can choose the version that best fits your project needs and find compatible extensions for charts, animations, zooming, data labels, and more. Whether you need basic charts or advanced visualizations with custom interactions, Chart.js provides the tools to build professional data displays efficiently.
https://github.com/chartjs/awesome
#typescript#charts#data_grid#data_table#date_picker#date_range_picker#hacktoberfest#react#time_picker
MUI X provides advanced React components like Data Grids, Date Pickers, Charts, and Tree Views for building data-rich apps, offering free MIT-licensed tools for basic needs and paid Pro/Premium plans with advanced features like server-side data handling and AI assistance, saving development time with ready-made solutions while allowing customization for any design system[1][2][4].
https://github.com/mui/mui-x