Toon posts:

Vervangen van een stuk HTML in Wordpress met REGEX?

Pagina: 1
Acties:

Vraag


  • xp2002
  • Registratie: Augustus 2002
  • Laatst online: 14-03-2022
Ik wil in mijn wordpress site (php met mysql) uit alle Posts een stuk tekst verwijderen. Hier zie je 3 voorbeelden die ik wil verwijderen uit een lijst van meer dan 500 posts:

Post 1 bevat:
[av_codeblock wrapper_element='' wrapper_element_attributes='' codeblock_type='' alb_description='' id='' custom_class='' av_uid='av-kjk757rf']
[voeg-datum-in]
[/av_codeblock]

Post 2 bevat:
[av_codeblock wrapper_element='' wrapper_element_attributes='' codeblock_type='' alb_description='' id='' custom_class='' av_uid='av-kjk76dur']
[voeg-datum-in]
[/av_codeblock]

Post 3 bevat
[av_codeblock wrapper_element='' wrapper_element_attributes='' codeblock_type='' alb_description='' id='' custom_class='' av_uid='av-kjk764nh']
[voeg-datum-in]
[/av_codeblock]

Deze bovenstaande blokken moeten weg uit alle posts, maar je ziet elke pagina heeft een andere uv_uid waarde in het blok zitten, dus ik kan niet zomaar zoeken en vervangen, omdat elk blok uniek is door die code.

Hoe krijg ik het voor elkaar dit soort blokken overal in een sweep te verwijderen? Ik moet een search replace kunnen doen met wildcards. Daar komt het op neer. Helaas ben ik niet vaardig in regular expressions.

...

Relevante software en hardware die ik gebruik:
Ik heb de plugin Better search replace voor Wordpress, maar dat werkt prima voor eenvoudige vervangingen.
...

Wat ik al gevonden of geprobeerd heb
- gezocht naar regular expressions, maar dat gaat mijn kennis te boven
- plugins gezocht
- gezocht op wildcards / replace / mysql. etc

Heeft iemand een doeltreffende oplossing voor mij?

Alvast bedankt!

Alle reacties


  • RobIII
  • Registratie: December 2001
  • Laatst online: 22:48

RobIII

Admin Devschuur®

^ Romeinse Ⅲ ja!

Probeer 't eens op regexr.com

There are only two hard problems in distributed systems: 2. Exactly-once delivery 1. Guaranteed order of messages 2. Exactly-once delivery.

Roses are red Violets are blue, Unexpected ‘{‘ on line 32.

Over mij


  • xp2002
  • Registratie: Augustus 2002
  • Laatst online: 14-03-2022
Dank je wel, hier kan ik zeker wat mee. Ik moet alleen uitzoeken hoe ik dit kan verwerken in een query. Volgens mij is dat ook niet heel eenvoudig als je er niet in zit. Ik heb maar basis kennis van phpmyadmin. Eens kijken of ik daar uit kom.

Bedankt in ieder geval!

  • NMe
  • Registratie: Februari 2004
  • Laatst online: 04-03 13:05

NMe

Quia Ego Sic Dico.

xp2002 schreef op donderdag 18 maart 2021 @ 11:35:
Dank je wel, hier kan ik zeker wat mee. Ik moet alleen uitzoeken hoe ik dit kan verwerken in een query. Volgens mij is dat ook niet heel eenvoudig als je er niet in zit. Ik heb maar basis kennis van phpmyadmin. Eens kijken of ik daar uit kom.

Bedankt in ieder geval!
https://dev.mysql.com/doc/refman/8.0/en/regexp.html

Overigens zou ik dit alléén met een regular expression doen als je 100% zeker weet dat er niet twee van die blokken in één tekst zitten of dat je expressie niet greedy is. Want anders loop je kans dat je niet alleen die blokken verwijdert maar ook alle teksten er tussenin omdat de expressie greedy heeft gematcht. Dat doet Rob's expressie hierboven overigens goed, maar of MySQL dat ook doet zul je heel goed moeten testen voordat je het loslaat op je livedata.

[Voor 15% gewijzigd door NMe op 18-03-2021 11:49]

'E's fighting in there!' he stuttered, grabbing the captain's arm.
'All by himself?' said the captain.
'No, with everyone!' shouted Nobby, hopping from one foot to the other.


  • Vihaio
  • Registratie: November 2006
  • Laatst online: 19-03 18:02
edit:
niet meer relevant na de edit van bovenstaand bericht

[Voor 73% gewijzigd door Vihaio op 18-03-2021 11:56]


  • RobIII
  • Registratie: December 2001
  • Laatst online: 22:48

RobIII

Admin Devschuur®

^ Romeinse Ⅲ ja!

Vihaio schreef op donderdag 18 maart 2021 @ 11:55:
De regex van @RobIII matcht toch lazy ipv greedy?

code:
1
.*?
Ik denk dat @NMe bedoelt dat je in het algemeen dat risico loopt als je 't niet goed doet ;)

There are only two hard problems in distributed systems: 2. Exactly-once delivery 1. Guaranteed order of messages 2. Exactly-once delivery.

Roses are red Violets are blue, Unexpected ‘{‘ on line 32.

Over mij


  • Vihaio
  • Registratie: November 2006
  • Laatst online: 19-03 18:02
Volgens mij beschreef hij het eerst iets anders. Zoals het er nu staat klopt het inderdaad.

  • xp2002
  • Registratie: Augustus 2002
  • Laatst online: 14-03-2022
Ik heb de expressie in ieder geval al uitgebreid met extra zekerheden, dus het enige dat variabel min of meer is, is de unieke code. (als ik het goed heb gedaan, tenminste)

\[av_codeblock wrapper_element=\'\' wrapper_element_attributes=\'\' codeblock_type=\'\' alb_description=\'\' id=\'\' custom_class=\'\' av_uid=(.*?)\[\/av_codeblock\]

  • KabouterSuper
  • Registratie: September 2005
  • Niet online
En de ranzige oplossing?
code:
1
[av_codeblock wrapper_element='' wrapper_element_attributes='' codeblock_type='' alb_description='' id='' custom_class='' av_uid='av-

vervangen door
code:
1
<!--

en
code:
1
2
[voeg-datum-in]
[/av_codeblock]

door
code:
1
//-->

  • xp2002
  • Registratie: Augustus 2002
  • Laatst online: 14-03-2022
Dus je zet comments om unieke code heen... dat is wel interessant en zou wel kunnen werken, maar wel eng op een grote blogsite :-)

  • KabouterSuper
  • Registratie: September 2005
  • Niet online
xp2002 schreef op donderdag 18 maart 2021 @ 13:36:
Dus je zet comments om unieke code heen... dat is wel interessant en zou wel kunnen werken, maar wel eng op een grote blogsite :-)
Weet je wat pas eng is? Regex!

Je kunt het altijd uitproberen met eentje, of de hele code in commentaar zetten ipv te vervangen met een commentaar teken. Of nog beter: tijdelijk in je php-code de replacements doen, dan hoef je nog niets structureel aan te passen.

En als het zo groot en belangrijk is, is het misschien tijd om een otap-straatje op te zetten.
Pagina: 1


Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee