- [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 — III. diel** </a>
 
  

 

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

 

 

 [    ![](https://www.mergado.sk/sites/default/files/perm/user-avatar/dan-mergado.jpg)   Daniel Czetner  ](/blog/daniel-czetner) [Pracujeme s Mergadom](/kategorie/pracujeme-s-mergadom) 

4. 11. 2016

3 minúty čítania

 

 

 

 

 

  ![](https://www.mergado.sk/sites/default/files/field/image/clanok-regexp-vol3.png)  

Bodky, otázniky aj zátvorky a ich použitie v regulárnych výrazoch už poznáte z predchádzajúcich dielov seriálu (ak nie, nájdete ich tu: [1. diel](http://www.mergado.sk/serial-regularne-vyrazy-1) a [2. diel](http://www.mergado.sk/serial-regularne-vyrazy-2)). Teraz prišiel čas na predstavenie a vysvetlenie ich praktického použitia, ktoré vám v Mergadu veľa uľahčia prácu.



 

 

 
                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>
  



 

Na úvod ešte trochu teórie, ktorá sa do minulých dielov nezmestila. V regulárnych výrazoch je **možné pracovať aj s negáciou**, a to pomocou striešky na začiatku množiny znakov. Napríklad:

- **\[^\\d\]** zodpovedá jednému znaku, ktorý nie je číslica,
- **\[^\\s\]** zodpovedá jednému znaku, ktorý nie je medzera (nejde o biely znak).

Regulárny výraz **\[^\\s\]\*$** tak bude **hľadať akékoľvek znaky od konca reťazca po prvú medzeru** (biely znak). Takto je možné nájsť napr. Posledné slovo alebo číslo v reťazci (pozri príklad, ku ktorému sme využili túto stránku).  
![](/sites/default/files/users/serial-regulary-3-regex1.png)

## EAN

EAN môže mnohokrát spôsobovať **problémy pri zobrazovaní produktov** vo vašom feede. Pozrieme sa teda na dva časté problémy s jeho využitím.

### 1. Hromadné odstránenie EAN kódov z popisku produktov

Pre odstránenie EANu z DESCRIPTION alebo napríklad CATEGORYTEXTU jednotlivých produktov potrebujeme využiť pravidlo s regulárnym výrazom, ktoré **vyhľadá číselný reťazec s dĺžkou 8 – 13 znakov** vrátane medzery za ním, a nahradí ho za “nič”. Využijeme teda pravidlo typu nájsť a nahradiť, pričom v elemente CATEGORYTEXT budeme vyhľadávať nasledujúce regulárny výraz: **\\d{8,13}\\s**, a do poľa pre nahradenie nezadáme nič.  
   
Toto pravidlo môžeme aplikovať na všetky produkty, nie je potreba robiť špeciálny výber — tam kde sa **EAN v popisku produktu nenájde sa nič nestane** a pravidlo sa neaplikuje.  
![](/sites/default/files/users/serial-regulary-3-ean1png.png)

### 2. Kontrola EANu

Chybná dĺžka EANu môže byť tiež častým zdrojom problémov napríklad **pri exporte dát do Google Merchant.** Pomocou regulárnych výrazov v Mergadu takú chybu ľahko odladíte.

Povedzme, že chcete vyhľadať všetky produkty, ktoré majú EAN zle — **obsahujú iný počet znakov ako 8 alebo 12 – 14** (čo sú najčastejšie dĺžky EANu). Budeme teda vyhľadávať také produkty, ktoré v elemente EAN **nemajú práve 8 alebo práve 12 – 14 znakov.** Tu využijeme striešku z úvodu, prípadne v jednoduchom rozhraní Mergada príkaz “neobsahuje regulárny výraz”: **^(\\ d{8}|\\d{12,14})$**

- **Strieška a dolár** označujú začiatok a koniec reťazca, v ktorom vyhľadávame (oproti predchádzajúcemu príkladu tentoraz EAN neobklopuje ďalší text).
- **\\d vyhľadáva číslice** — buď presne 8 ľubovoľných číslic (osmička v zloženej zátvorke) alebo (zvislou čiarou) presne 12 — 14 ľubovoľných číslic.

![](/sites/default/files/users/serial-regulary-3-regvyraz.png)

## Odstránenie veľkosti z PRODUCTNAME

Niektoré porovnávače — napríklad Glami — požadujú, aby **element PRODUCTNAME neobsahoval informáciu o veľkosti produktu**, pretože pre ňu má špeciálny element PARAM. V prípade, že máte svoje produkty v e‑shope takto pomenované, potrebujete časť názvu zmazať u veľkého množstva položiek. Ako na to?

Pomocou pravidlá nájsť a nahradiť budeme hľadať konkrétne regulárny výraz: **veľkosť\\s\*\[\\ dSMLX\]+** a nahrádzať za “nič”.  
   
Chceme totiž nájsť slovné spojenie veľkosti a písmená alebo čísla, ktoré danú veľkosť označuje, pričom medzi slovom “veľkosť” a hodnotou môže byť ľubovoľný počet medzier.

Poďme ale postupne a ukážme si, ako takýto zápis vytvoriť:

1. veľkosť — **hľadáme reťazec, v ktorom je slovo “veľkosť”,**
2. hodnota veľkosti — vieme, že hodnoty označujeme písmenom (S, M, L, …) a občas tiež kombináciou písmená a čísla (napr. 4XL). Preto **použijeme zápis \\d, ktorý vyhľadáva všetky čísla od 0 do 9**, a následne vymenujeme všetky písmená, z ktorých aspoň jedno sa vo výraze nachádza (preto hranaté zátvorky),
3. toto označenie môže byť **kdekoľvek v reťazci**, nepoužijeme teda **značky pre začiatok alebo koniec reťazca**,
4. medzi slovom “veľkosť” a samotnou hodnotou **môže byť medzera** (alebo viac medzier) a **alebo tiež nemusí** (napr. veľkostXL, veľkosť XL), preto použijeme vyhľadávanie medzier **pomocou výrazu \\s**, hviezdička potom hovorí, že sa tam má medzera vyskytovať **0 až nespočetnekrát**,
5. znamienko **plus na konci reťazca určuje**, že sa celý hľadaný výraz v hranatých zátvorkách vyskytuje v našom reťazci **aspoň raz.**

![](/sites/default/files/users/serial-regulary-3-productname.png)

Snáď ste sa v záplave zátvoriek a striešok nestratili. Ak áno, neváhajte sa nám ozvať na [fórum](http://forum.mergado.cz) alebo [e‑mail](mailto:mergado@mergado.sk), radi vám pomôžeme sa nájsť!



 

- [  Regulárne výrazy ](/tema/regularne-vyrazy)
 
 [    ![](https://www.mergado.sk/sites/default/files/perm/user-avatar/dan-mergado.jpg)  ](/blog/daniel-czetner)###  [ Daniel Czetner ](/blog/daniel-czetner) 

Daniela ste poznali zo slovenskej podpory Mergada. Pomáhal riešiť problémy, písal návody v nápovede a testoval nové funkcie v Mergade. Mal jednoznačne najdlhšie dredy v tíme a jeho drsnému humoru sa vyrovnal snáď len jeho spolupracovník Přemek.

 

 

 

 

 

 

 

 

 

## 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()
      }