- [Case Studies](/kategorie/case-studies)
- [E‑commerce tipy](/kategorie/e-commerce-tipy)
- [E‑shopové riešenia a platformy](/kategorie/e-shopove-riesenia-platformy)
- [Mergado Pack](/kategorie/mergado-pack)
- [Mergado tipy](/kategorie/mergado-tipy)
- [Novinky v Mergade](/kategorie/novinky-v-mergade)
- [Novinky z porovnávačov cien](/kategorie/novinky-z-porovnavacov-cien)
- [Pracujeme s Mergadom](/kategorie/pracujeme-s-mergadom)
- [Rozhovory](/kategorie/rozhovory)
- [Rozšírenia](/kategorie/aplikacie)
- [S Mergadom do zahraničia](/kategorie/s-mergadom-do-zahranicia)
- [Zo života Mergada](/kategorie/zo-zivota-mergada)
 



 

 1. [  Domov  ](/)
2. [     Blog  ](/blog)
3. [     Pracujeme s Mergadom  ](/kategorie/pracujeme-s-mergadom)
4. <a class="flex items-center gap-2 hover:underline" href="" itemid="" itemprop="item" itemscope="" itemtype="https://schema.org/Thing">    **Ako na regulárne výrazy v Mergade — IV. diel** </a>
 
  

 

#  **Ako na regulárne výrazy v Mergade — IV. diel** 

 

 

 [    ![](https://www.mergado.sk/sites/default/files/perm/image/luda_0.png)   Luděk Volejník  ](/blog/ludek-volejnik) [Pracujeme s Mergadom](/kategorie/pracujeme-s-mergadom) 

11. 11. 2016

3 minúty čítania

 

 

 

 

 

  ![](https://www.mergado.sk/sites/default/files/field/image/regvyrazy4.png)  

Seriál článkov o regulárnych výrazoch sa pomaly blíži do finále a preto by som vám chcel v dnešnom diely zhrnul niektoré dôležité poznatky a pridal pár skutočných regulárnych fines, ktoré určite v práci s Mergadom oceníte.

\*/



 

 

 
                function tableOfContents() {
                  return {
                    headings_menu: [],
                    heading_active: '', // Added to track the active section
                    shouldBeSticky: false,

                    generateToC() {
                      const headings = document.querySelectorAll('.js-article-full-headings h2, .js-article-full-headings h3');
                      let headingMap = {};

                      headings.forEach((heading) => { // Use an arrow function to maintain `this` context
                        // Normalize heading text to remove diacritics, then replace non-alphanumeric characters with dashes
                        var normalizedText = heading.textContent.normalize("NFD").replace(/[\u0300-\u036f]/g, ""); // Remove diacritics
                        var id = heading.id ? heading.id : normalizedText.trim().toLowerCase()
                          .split(' ').join('-').replace(/[^a-z0-9\-]/ig, ''); // Updated regex to replace non-alphanumeric characters
                        headingMap[id] = headingMap[id] !== undefined ? ++headingMap[id] : 0;

                        // Use the updated `id` with diacritics removed for the heading id and the TOC
                        const finalId = headingMap[id] ? `${id}-${headingMap[id]}` : id;
                        this.headings_menu.push({
                          id: finalId,
                          title: heading.textContent,
                          level: heading.tagName.toLowerCase(), // Track heading level
                          active: false, // Initially set active to false
                        });
                        heading.id = finalId;
                      });
                    },

                    checkStickyNeeded() {
                      const ul = this.$el.querySelector('ul');
                      if (ul) {
                        this.shouldBeSticky = ul.scrollHeight < window.innerHeight;
                      }
                    },

                    setActiveHeading() {
                      // disabled not working with active state on click
                      // add @scroll.window="setActiveHeading()" to the parent div

                      // const headings = document.querySelectorAll('.js-article-full-headings h2');
                      // let activeHeading = '';
                      // let closestHeadingDistance = Infinity;

                      // headings.forEach((heading) => {
                      //   const rect = heading.getBoundingClientRect();
                      //   const offset = rect.top - window.innerHeight / 2; // Consider heading in the middle of the screen as active

                      //   if (offset < 0 && Math.abs(offset) < closestHeadingDistance) {
                      //     activeHeading = heading.id;
                      //     closestHeadingDistance = Math.abs(offset);
                      //   }
                      // });

                      // // Update the active state in headings_menu
                      // if (activeHeading !== this.heading_active) {
                      //   this.headings_menu = this.headings_menu.map(item => ({
                      //     ...item,
                      //     active: item.id === activeHeading,
                      //   }));
                      //   this.heading_active = activeHeading;

                      // }
                    },

                    setActiveItem(clickedId) {
                      this.headings_menu.forEach(item => {
                        item.active = (item.id === clickedId);
                      });
                      this.heading_active = clickedId; // Optionally update the heading_active property if used
                    },
                  };
                }
               1. <a :class="{ 'border-r-[3px] border-secondary': item.active, 'text-sm': item.level === 'h3' }" :href="'#' + item.id" class="inline-block text-balance hover:underline p-0.5 pr-3">  — </a>
  



 

Ak si chcete osviežiť doterajšie vedomosti o regulároch alebo vám niektorý z predchádzajúcich dielov unikol, mrknite sa na jednotlivé články — [1. diel](http://www.mergado.sk/serial-regularne-vyrazy-1), [2. diel](http://www.mergado.sk/serial-regularne-vyrazy-2), [3. diel](http://www.mergado.sk/serial-regularne-vyrazy-3).

## Užitočné značky pre regulárne výrazy

Pri predstavovaní jednotlivých značiek som vynechal ešte dve dôležité a šikovné — **\\D a \\S**. Teraz to napravím:

- **\\D** funguje ako negácia malého **\\d** , teda vyhľadá všetky znaky, ktoré nie sú číslom a je teda ekvivalentná výrazu, ktorý som predstavil minule — **\[^\\d\]**
- **\\S** potom vyhľadáva také znaky, ktoré **nepatria medzi biele**, teda nejde o medzery, tabulátory, nové riadky a pod., taktiež je ekvivalentná výrazu z minula — **\[^\\s\]**

Pre prehľadnosť ešte pridávam tabuľku všetkých značiek, ktoré v príkladoch používam.

**REGULÁRNÍY VÝRAZ****VYHĽADÁ****.** bodka práve jeden neznámý znak**\*** hviezdička konkrétny znak 0 až nekonečne krát**?** otáznik konkrétny znak 0 alebo 1 krát (znak se nevyskytuje alebo vyskytuje len raz)**+** pluskonkrétny znak 1 až nekonečne krát (znak sa vyskytuje aspoň raz)**\[\]** hranaté zátvorkyjeden zo skupiny hľadaných znakov**{}** zložené zátvorkyx opakovaní znaku alebo skupiny znakov pred zátvorkou**^** strieškaod začiatku reťazca**$** dolárod konca reťazca**|** vertikálajeden ALEBO druhý znak (slovensky alebo)**\\s**medzeru a ďalšie biele znaky (tabulátory, nové riadky)**\\d** zastupuje čísla od 0 do 9**\\S** alebo **\[^\\s\]**čokoľvek okrem bielych znakov, teda čísla a písmená (negácia \\s)**\\D** alebo **\[^\\d\]**čokoľvek okrem položiek, teda biele znaky a písmená (negácia \\d)## Zložitejšie príklady

A teraz tie avizované zložitejšie príklady. Na niektoré ste sa nás pýtali na fóre, o iných si myslím, že ich regulárne výrazy riešia elegantne.

Častým nedostatkom feedov sú **chýbajúce alebo zle naplnené elementy.** Podobne často sa požadovaná informácia vyskytuje **na inom mieste vo vašom kóde** a je teda logickým riešením ju odtiaľ prepísať do správneho elementu. Najprv je nutné **skontrolovať, že takýto element náš feed obsahuje** a ak nie, tak ho na karte *Pravidlá* doplniť. Zároveň predpokladajme, že sa tento problém týka **viac ako dvoch desiatok produktov** (inak by bolo ľahšie riešiť ho ručne). Chceme preto **zautomatizovať prepisovanie** tak, aby Mergado poznalo, kde má informáciu vziať. Pozrime sa na to pomocou príkladu:

1. Naším zámerom je **naplniť element MANUFACTURER** informáciami o výrobcovi, ktorá sa nachádza na začiatku PRODUCTNAME.
2. V prvom kroku tak **vytvoríme premennú s názvom MANUFACTURER**, ktorej náplňou bude prvé slovo z elementu PRODUCTNAME. (Novú premennú pridáte na karte Pravidlá v pravom stĺpci skrze príkaz Upraviť premenné).
3. To zariadime pomocou regulárneho výrazu: **^\\S+** Tento regulárny výraz **hľadá od začiatku reťazca akékoľvek znaky do prvej medzery**, nájde teda prvé slovo v reťazci, a je preto použiteľný pre jednoslovné názvy výrobcov, napr. Addidas, Nike, Reebok, atď.
4. Túto premennú potom **vložíme** pomocou pravidla *Prepísať* **do elementu MANUFACTURER.**

![](/sites/default/files/users/manufacturer3.png)

Obdobne môžeme postupovať aj u vyhľadávania na inom mieste v konkrétnom elemente:

- **prvé slovo** v texte **^\\S+**
- **prvé dve slová** od začiatku textu **^(\\s\*\\S+){2}**
- **posledné slovo** na konci textu, vrátane prípadnej interpunkcie na konci **\\S+$**
- **posledné dve slová** na konci textu, vrátane prípadnej interpunkcie na konci **(\\S+\\s\*){2}$**

## Duplicitné slová v elemente

Ak chceme nájsť **duplicitné slová v jednom elemente**, môžeme taktiež využiť regulárne výrazy. Poslúži nám pre spätnú kontrolu dát, a pravidiel, ktoré sme pre ich správu nastavili. Napríklad chceme vyhľadať **duplicity v PRODUCTNAME**, môžeme takéto produkty vyhľadať pomocou regulárneho výrazu: **(\\S+)(.\*)\\1** Zjednodušene týmto príkazom Mergadu hovoríme: nájdi **reťazec znakov (napr. slovo), za ktorým je ľubovoľný text a následne sa takáto skupina znakov (teda napr. to slovo) znovu opakuje.** Výraz neberie ohľad na interpunkciu, nájde teda výrazy, za ktorými je čiarka aj bodka a zároveň aj výrazy bez týchto znamienok. Dôležité je spomenúť, že ide **o zjednodušený príklad** a taký regulárny výraz nebude vyhovovať všetkým kombináciám, ktoré môžu v texte nastať. Pre naše účely použitia v Mergadu však myslím postačí. V prípade, že duplicity skutočne nájdete, oplatí sa pozrieť do pravidiel, akým spôsobom sa nám tam dostali (mohli to spôsobiť napríklad opakujúce sa pravidlá). Ak máte ďalšie otázky k regulárnym výrazom alebo Mergadu všeobecne, ozvite sa nám do komentárov, do [fóra](http://forum.mergado.cz) alebo priamo na [podporu](mailto:mergado@mergado.sk).



 

- [  Regulárne výrazy ](/tema/regularne-vyrazy)
 
 [    ![](https://www.mergado.sk/sites/default/files/perm/image/luda_0.png)  ](/blog/ludek-volejnik)###  [ Luděk Volejník ](/blog/ludek-volejnik) 

Senior konzultant Mergada Luďek pôsobil **v oblasti e‑commerce vyše 15 rokov**. Ostrieľaný support master a lektor vás viedol zákutiami Mergada aj svetom regulárnych výrazov. Na svojom konte má **stovky vyškolených užívateľov Mergada**, ktorí sa stali uznávanými odborníkmi na feed marketing, PPC a SEO.

 

 

 

 

 

 

 

 

 

## Mohlo by vás *zaujímať*

 

 [    ![](https://www.mergado.sk/sites/default/files/perm/image/shoptet_shopify_sk.jpg)  

### Ako sme s Mergadom previedli e‑shop zo Shoptetu na Shopify: kompletná migrácia bez straty dát

 

 ](/blog/ako-sme-s-mergadom-previedli-e-shop-zo-shoptetu-na-shopify-kompletna-migracia-bez-straty-dat) 

 [    ![nastavenie uživatelských účtov](https://www.mergado.sk/sites/default/files/perm/image/new-nahladovka-na-blog-1200-x-628-px-38.png)  

### Ako nastavovať užívateľské účty agentúrnych pracovníkov v Mergade

 

 ](/blog/opravnenie-uzivatelskych-uctov-pre-agentury) 

 [    ![produktový feed 5 najčastějších cýb](https://www.mergado.sk/sites/default/files/perm/image/new-nahladovka-na-blog-1200-x-628-px-19_0.png)  

### 5 najčastejších chýb v produktovom feede a ako ich upraviť v Mergade

 

 ](/blog/najcastejsie-chyby-v-produktovom-feede) 

 

 

 

## Nenechajte si nič *ujsť*

 Prihláste sa k odberu nášho newslettera 

   

       

   Prihlásením súhlasíte s tým, že vaše údaje budeme spracovávať v súlade s našimi [zásadami ochrany osobných údajov](/vyhlasenie-o-cookies). 

  Ďakujeme, úspešne ste sa pripojili k nášmu zoznamu odberateľov. 

 

 

 
      function ml_webform_success_5807248() {
        var r = ml_jQuery || jQuery
        r('.ml-subscribe-form-5807248 .row-success').show(), r('.ml-subscribe-form-5807248 .row-form').hide()
      }