Nettoyer code HTML pour un select LENGTH(name)
Résolu
pcsystemd
Messages postés
702
Date d'inscription
Statut
Membre
Dernière intervention
-
pcsystemd Messages postés 702 Date d'inscription Statut Membre Dernière intervention - 1 oct. 2020 à 15:34
pcsystemd Messages postés 702 Date d'inscription Statut Membre Dernière intervention - 1 oct. 2020 à 15:34
A voir également:
- Nettoyer code HTML pour un select LENGTH(name)
- Code ascii - Guide
- Nettoyer ordinateur portable lent - Guide
- Nettoyer son mac - Guide
- Comment déverrouiller un téléphone quand on a oublié le code - Guide
- Code puk bloqué - Guide
3 réponses
Bonjour,
à tout hasard, regardes ceci :
https://blog.webnersolutions.com/postgres-function-to-remove-html-tags-from-text/
A+
à tout hasard, regardes ceci :
https://blog.webnersolutions.com/postgres-function-to-remove-html-tags-from-text/
A+
Bonjour,
RV71
Merci effectivement cela est une bonne piste que je vais tester.
Reivax962
J'ai pas tout compris! Un exemple? Merci
RV71
Merci effectivement cela est une bonne piste que je vais tester.
Reivax962
J'ai pas tout compris! Un exemple? Merci
Ce que je veux dire, c'est qu'un code HTML risque aussi de contenir des codes du genre « & lt; », « & eacute; » ou autre, qu'il faut compter comme un seul caractère et non comme, respectivement, 4 et 8.
Ça peut se faire simplement en reprenant la fonction donnée par RV71, en y remplaçant < par & et > par ;
Et tu peux créer une troisième fonction qui combine les deux premières :
Un texte comme
Xavier
PS : sur le forum, les caractères &...; sont reconnus et transcrits, je suis obligé de rajouter une espace après le & éviter ça, mais elle ne doit pas y être normalement.
Ça peut se faire simplement en reprenant la fonction donnée par RV71, en y remplaçant < par & et > par ;
CREATE OR REPLACE FUNCTION strip_html_caracs(TEXT) RETURNS TEXT AS $$ SELECT regexp_replace($1, '&[^;\s]*;', '_', 'g'); $$ LANGUAGE SQL;
Et tu peux créer une troisième fonction qui combine les deux premières :
CREATE OR REPLACE FUNCTION strip_html(TEXT) RETURNS TEXT AS $$ SELECT strip_html_caracs(strip_tags($1)); $$ LANGUAGE SQL;
Un texte comme
<h1>L& apos;& eacute;valuation du nombre de caract& egrave;es</h1>sera transformé en
L__valuation du nombre de caract_reset tu pourras donc correctement y compter les caractères.
Xavier
PS : sur le forum, les caractères &...; sont reconnus et transcrits, je suis obligé de rajouter une espace après le & éviter ça, mais elle ne doit pas y être normalement.
J'ai pris le parti de remplacer les caractères spéciaux par _ car le but est simplement de les compter.
Si tu voulais qu'ils soient remplacés par leur vraie valeur, ça va être plus compliqué mais c'est possible : https://stackoverflow.com/questions/14961992/postgresql-replace-html-entities-function
Xavier
Si tu voulais qu'ils soient remplacés par leur vraie valeur, ça va être plus compliqué mais c'est possible : https://stackoverflow.com/questions/14961992/postgresql-replace-html-entities-function
Xavier
Xavier