TGTGInsighttelegram intelligenceLIVE / telegram public index
← Python Заметки

TGINSIGHT SIMILAR POSTS

Најди сличен содржај

Изворен канал @pythonotes · Post #121 · 20 јул.

Регулярно требуется преобразовать какой-либо текст в максимально совместимый текст для URL, имени файла, имени объекта в каком-то софте и тд. Требования совместимости простые: в тексте должны быть только допустимые символы. Обычно это a-z, 0-9 и "_" или "-". То есть, только прописные буквы латинского алфавита и цифры (как пример). Допустим, нам нужно название статьи в блоге преобразовать в slug для добавления его в URL этой статьи. Как это лучше всего сделать? В Django по умолчанию есть готовая функция slugify для таких случаев. Но я её никогда не использую. Почему? Потому что её недостаточно! Приведём пример >>> from django.utils.text import slugify >>> slugify('This is a Title') 'this-is-a-title' Пока всё отлично >>> slugify('This is a "Title!"') 'this-is-a-title' Спец символы удалились, всё хорошо. >>> slugify('Это заголовок статьи') '' Вот и приехали 😢. Если текст не английский то буквы просто игнорируются. Можно это поправить >>> slugify('Это заголовок статьи', allow_unicode=True) 'это-заголовок-статьи' Но тогда мы не вписываемся в условие. У нас появилась кириллица в тексте. Так как я часто пишу сайты для русскоязычных пользователей эта проблема весьма актуальна. Я не использую стандартную функцию и всегда пишу свою. Оригинал я не беру в расчёт и пишу полностью свою функцию. И так, по порядку: 🔸1. Исходный текст: >>> text = 'Мой заголовок №10 😁!' Взял специально посложней со специальными символами. 🔸2. Транслит Необходимо сделать транслит всех символов в латиницу. Здесь очень выручает библиотека unidecode. Помимо простого транслита кириллицы в латиницу она умеет преобразовывать спец символы и иероглифы в текстовые аналоги. from unidecode import unidecode >>> unidecode("Ñ Σ ® µ ¶ ¼ 月 山") 'N S (r) u P 1/4 Yue Shan' Очень крутая библиотека, советую👍 В нашем случае получаем такое преобразование: >>> text = unidecode(text) >>> print(text) 'Moi zagolovok No. 10 !' Отличный транслит. Смайл просто удалился, хотя я ждал что-то вроде :). Ну и ладно, всë равно невалидные символы. А еще наш код уже поддерживает любой язык, будь то хинди или корейский. 🔸4. Фильтр символов Unidecode не занимается фильтрацией по недопустимым символам. Это мы делаем в следующем шаге через regex. Просто заменим все символы на "_" если они вне указанного диапазона. >>> text = re.sub(r'[^a-zA-Z0-9]+', '_', text) >>> print(text) 'Moi_zagolovok_No_10_' Символ "+" в паттерне выручает когда несколько недопустимых символов идут рядом. Все они заменяются на один символ "_". 🔸5. Slugify Осталось удалить лишние символы по краям и сделать нижний регистр >>> text = text.strip('_').lower() >>> print(text) 'moi_zagolovok_no_10' Получаем отличный slug! 😎 🌎 Полный код в виде функции. ______________ PS. Проверку что в строке остался хоть один допустимый символ я бы вынес в отдельную функцию. #libs#tricks#django

Резултати

Пронајдени 3 слични објави

Пребарај: #fcs

当前筛选 #fcs清除筛选
Ambassade de Russie au Burkina Faso

@russie_burkinafaso · Post #543 · 03.12.2025 г., 15:03

🗞Article de Sergueï Lavrov, Ministre des Affaires étrangères de la Fédération de Russie, pour Rossiïskaïa Gazeta à l'occasion de la réunion du Conseil des ministres des Affaires étrangères de l'OSCE à Vienne (3 décembre 2025) « La dégradation de l'OSCE est le prix à payer pour servir les intérêts de l'Occident » 💬 Prochainement, les 4 et 5 décembre, le Conseil des ministres des Affaires étrangères de l'OSCE se réunira à Vienne pour sa session annuelle. La Russie traditionnellement participe activement au travail de ce mécanisme consultatif. Cette fois-ci, à l'occasion du 50e anniversaire de la signature de l'Acte final d'Helsinki, la délégation russe accordera une attention particulière à la genèse de la situation actuelle à Vienne. Je dirai tout de suite que la situation est déplorable. Le processus paneuropéen a été lancé au tournant des années 1960 et 1970 afin de : • surmonter la division de l'Europe • réduire la confrontation militaire et politique • développer la coopération commerciale et économique. La fin de la guerre froide et la confrontation entre les blocs ont offert l'opportunité de créer une architecture paneuropéenne de sécurité égale et indivisible. L'OSCE aurait pu en devenir la pierre angulaire. Lors de sa création en 1994, elle a réuni d'anciens membres du Pacte de Varsovie, des membres de l'OTAN et des pays neutres. Dans le cadre de l'OSCE, un engagement politique crucial a été convenu au plus haut niveau de ne pas renforcer sa sécurité au détriment de celle des autres. [...] Le problème est que les pays participants de l'OSCE, représentant l'Occident collectif, n'ont pas respecté cet engagement, préférant s'appuyer sur un système de sécurité européen de l'OTAN. Depuis le milieu des années 1990, ils n'ont cessé d'élargir l'Alliance atlantique vers l'Est, en dépit des affirmations faites aux dirigeants soviétiques de ne pas le faire. [...] Malgré la résistance de l'OTAN et de l'UE, la Russie parvient à empêcher l'abolition du principe de consensus au sein du Forum pour la coopération sur la sécurité (#FCS), principal forum de l'OSCE pour examiner les questions de sécurité militaire. [...] 👉L'OSCE n'a pas réussi à devenir un médiateur impartial dans le règlement des conflits régionaux. L'OSCE s'est écartée du principe d'impartialité dans la crise ukrainienne, fermant les yeux sur le sabotage par Kiev des accords de Minsk de 2015, avec le consentement de Berlin et de Paris, et sur les crimes commis par les combattants des forces armées ukrainiennes contre les civils dans le Donbass, depuis l'opération antiterroriste de 2014 jusqu'à aujourd'hui. L'ukrainisation a également affecté l'économie. L'OSCE a abandonné ses acquis de lutte contre la corruption, de développement de l'économie numérique et de construction d'infrastructures de transport. On en est arrivé à un point où, contrairement à l'esprit et à la lettre d'Helsinki, des mesures coercitives unilatérales sont justifiées au Forum de Vienne. [...] La situation dans la dimension humaine, ce qu'on appelle le troisième panier utilisé par l'Occident pour s'ingérer dans les affaires intérieures de l'URSS et de la Russie contemporaine, laisse à désirer. Des questions aussi cruciales que la promotion du dialogue interculturel, la lutte contre les manifestations du néonazisme, de l'islamophobie et de la christianophobie, ainsi que la protection des droits des minorités nationales et des croyants, ont été reléguées de l'ordre du jour. [...] L'OSCE ferme également les yeux sur la censure des médias russes en Occident. En utilisant la délivrance des visas comme levier, des militants de la société civile russe sont empêchés de participer aux événements de l'OSCE. [...] Il n'y a aucune raison d'être optimiste. Il n'y a pas de lumière au bout du tunnel. ☝️ Mais il y a un moyen d'éviter l'effondrement de l'OSCE, du moins pour l'instant. Pour cela, il faut que tous les participants à l'OSCE respectent les principes d'Helsinki du dialogue égalitaire et respectueux. 📰Texte intégral de l'article (Telegraph)

Hashtags

Tutto Elezioni

@tuttoelezioni · Post #1357 · 27.10.2025 г., 07:18

#Argentina🇦🇷 #Parlamentari Risultati parziali. Senato. Sezioni scrutinate: 25.571/25.861 (98,87%). 🟪 La Libertà Avanza (#LLA|Libertaristi di destra): 42,03% (13) 🟦 Forza Patria (#FP|Centrosinistra peronista): 23,21% (6) 🟥 Fronte Civico per Santiago (#FCS): 6,17% (2) 🟦 Forza Entre Ríos (#FER): 5,20% (1) Prima i Salteni (#PS): 3,60% (1) 🟥 Fronte di Sinistra (#FITU|Trotskisti): 2,74% (0) Altri: 17,05% (1) N.B.: Tra parentesi sono indicati i seggi ottenuti. @TuttoElezioni

Tutto Elezioni

@tuttoelezioni · Post #1356 · 27.10.2025 г., 07:15

#Argentina🇦🇷 #Parlamentari Risultati parziali. Camera dei deputati. Sezioni scrutinate: 108.125/108.992 (99,20%). 🟪 La Libertà Avanza (#LLA|Libertaristi di destra): 40,65% (64) 🟦 Forza Patria (#FP|Centrosinistra peronista): 24,31% (31) 🟦 Province Unite (#PU|Centro): 4,96% (5) 🟥 Fronte di Sinistra (#FITU|Trotskisti): 3,71% (3) 🟦 Fronte Prima il Tucumán (#FTP): 2,28% (2) 🟥 Fronte Civico per Santiago (#FCS): 1,23% (2) 🟦 Forza Giustizialista Mendoza (#FJM): 1,10% (1) 🟦 Forza Entre Ríos (#FER): 1,06% (2) 🟪 Proposta federale per il cambiamento (#PFC): 1,05% (0) Altri: 19,65% (17) N.B.: Tra parentesi sono indicati i seggi ottenuti. @TuttoElezioni