abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:00 | Nová verze

    Byla vydána nová verze 15.0 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    dnes 03:00 | Nová verze

    UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04 1.1 a 20.04 OTA-11. Vedle oprav chyb a drobných vylepšení je řešen také středně závažný bezpečnostní problém.

    Ladislav Hagara | Komentářů: 0
    dnes 00:33 | IT novinky Ladislav Hagara | Komentářů: 0
    včera 16:00 | Komunita

    Fedora zve na dvoudenní testování (2. a 3. prosince), během kterého si můžete vyzkoušet nové webové uživatelské rozhraní (WebUI) projektu FreeIPA. Pomozte vychytat veškeré chyby a vylepšit uživatelskou zkušenost ještě předtím, než se tato verze dostane k uživatelům Fedory a celého linuxového ekosystému.

    Ladislav Hagara | Komentářů: 3
    včera 13:22 | IT novinky

    Eben Upton oznámil zdražení počítačů Raspberry Pi, kvůli růstu cen pamětí, a představil 1GB verzi Raspberry Pi 5 za 45 dolarů.

    Ladislav Hagara | Komentářů: 0
    včera 04:44 | Humor

    Linus Torvalds na YouTube kanálu Linus Tech Tips staví dokonalý linuxový počítač.

    Ladislav Hagara | Komentářů: 6
    včera 04:11 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 6.17 oznámil Linus Torvalds vydání Linuxu 6.18. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a Linux Kernel Newbies. Vypíchnout lze například podporu protokolu PSP (PSP Security Protocol, PSP encryption of TCP connections).

    Ladislav Hagara | Komentářů: 0
    včera 03:55 | Nová verze

    Byla vydána nová stabilní verze 25.11 linuxové distribuce NixOS (Wikipedie). Její kódové označení je Xantusia. Podrobný přehled novinek v poznámkách k vydání. O balíčky se v NixOS stará správce balíčků Nix.

    Ladislav Hagara | Komentářů: 0
    včera 03:22 | Komunita

    Richard Hughes na Mastodonu oznámil, že se společnost Framework Computer stala sponzorem služby LVFS (Linux Vendor Firmware Service) umožňující aktualizovat firmware zařízení na počítačích s Linuxem.

    Ladislav Hagara | Komentářů: 0
    28.11. 18:55 | Humor

    Jak na webu co nejšíleněji zadávat datum? Jak to uživatelům co nejvíce znepříjemnit? V Bad UX World Cup 2025 (YouTube) se vybíraly ty nejšílenější UX návrhy. Vítězným návrhem se stal Perfect Date.

    Ladislav Hagara | Komentářů: 18
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (47%)
     (19%)
     (18%)
     (23%)
     (16%)
     (24%)
     (16%)
     (18%)
    Celkem 423 hlasů
     Komentářů: 17, poslední 19.11. 21:57
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: funkce fseek()

    9.12.2009 08:22 Okallasch | skóre: 1
    funkce fseek()
    Přečteno: 455×
    Příloha:
    Dobrý den, Mohl by mi prosím někdo poradit jak použít funkci fseek() v tomto případě:

    Mám vytvořenej externí seznam kalendáře tímto způsobem(viz. příloha)

    A potřebuju aby se dělo todle: Poté co uživatel v hlavní nabídce vybere možnost kalendář mělo by se na obrazovku vytisknout svátek na ten den + 7 dalších dnů. Zatim to pracuje tak, že po vybrání kalendáře v hlavní nabídce se vytiskne na obrazovku celý seznam.

    Předem děkuju za rady.

    Odpovědi

    9.12.2009 08:29 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: funkce fseek()
    To je nejake zadanie, ktoreho sucastou je, ze je nutne pouzit prave fseek()? Pretoze mi to pride ako dost nesikovne riesenie. Osobne by som natiahol do pamate cely kalendar, kazdy den zabaleny vo vhodnom objekte, a v pripade poziadavky by som len zo zotriedenho zoznamu takychto objektov vytiahol prislusny pocet poloziek. Triedenie ani netreba riesit, ak je dane, ze vstupny subor je zotriedeny. Vyriesit treba len cyklickost zoznamu, aby sa nasledujucich 7 dni vratilo aj v pripade, ze pouzivatel zvoli datum z posledneho tyzdna roka. Ak je zoznam v poli, tak staci obycajne delenie modulo.
    9.12.2009 08:35 Okallasch | skóre: 1
    Rozbalit Rozbalit vše Re: funkce fseek()
    Ne fseek() neni podmínkou byla to jen moje myšlenka. Jen si nejsem jist jestli jsem vás dobře pochopil. Tak se jen ujistím. Váš návrh je nahrát každý řádek ze souboru do proměnné? a podle potřeby ji volat zpět?
    e.lisak avatar 9.12.2009 10:50 e.lisak | skóre: 23
    Rozbalit Rozbalit vše Re: funkce fseek()
    a co nacist cely ten soubor do pameti (nejakych 9kB neni moc...), pripadne do pole (svatky[366]), a rovnou adresovat/vypisovat zadany den+[0..6] (+osetreni modulo pocet dni v roce ;-))
    9.12.2009 10:55 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: funkce fseek()
    Moj navrh je sekvencne citat subor, mena mesiacov ignorovat, kazdy neprazdny riadok rozparsovat do "struktury" (struct v C, objekt v Jave, a pod.) a tieto struktury umiestnit do pola. Ked si pouzivatel zaziada 16. januar, najst v poli strukturu pre 16. januar a vratit tuto strukturu a nasledujucich N struktur. Nebudete predsa pre kazdy pouzivatelov request liezt do suboru. Iba ze by sa jednalo o "jednorazovu" utilitku, ale vzhadom na potrebu riesit "koniec roka", aj v tom pripade by som zostal pri navrhovanom rieseni.

    Osetrit priestupne roky. :-)

    9.12.2009 12:15 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: funkce fseek()
    Seek má smysl tam, kde víte předem, na jakou pozici (tj. kolik bytů od začátku (konce)) se potřebujete přesunout. Tohle není ten případ, tady by nezbyde než to projít sekvenčně po řádcích, např. pomocí fgets().
    9.12.2009 08:40 mich | skóre: 16
    Rozbalit Rozbalit vše Re: funkce fseek()
    Možná jsem mimo, ale vzhledem k tomu, že každý den má jinak dlouhý záznam, tak se ti to moc dobře seekovat nebude (pokud nechceš mít v kódu 365 konstant s pozicemi jednotlivých dnů v souboru:-)). Normálně to přečti všechno.
    je to teď v módě, na žive o tom furt píšou
    9.12.2009 11:08 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: funkce fseek()
    Je to dost nevhodný formát na fci seek :), jedině tam doplnit mezery na pevnou šířku řádku nebo vytvořit index :)
    Tady je "rozvláčné" řešní v PHP (bo jazyk nebyl specifikován a princip je z toho jasný):
      //nastavení
      $max_days = 7;
    
      //vypis to nejak
      function PrintMe($line)
      {
        print nl2br($line);
      }
       
      if(($lines = file("mujfiles.neco")) === false)//nacti files do pole
      {
        echo "error, file not found";
      }
      else
      {
        $now = time();
        $day = (int) date("d",$now);
        $month = (int) date("n",$now);
        $cnt = count($lines);
        for($i = 0;$i < $cnt;$i++)
        {
          $a = explode ('.', $lines[$i], 3);
          if(count($a) == 3)//je to ten spravny radek ?
          {
            if((IntVal($a[0]) == $day)&&(IntVal($a[1]) == $month))//je to dnes ?
            {
              PrintMe($lines[$i]);
              $rewind = 0;
              $j=0;
              while($j < $max_days && $rewind < 2)//konec roku, 1× přemotat
              {
                for($i++;$i < $cnt && $j < $max_days;$i++)
                { 
                  $a = explode ('.', $lines[$i], 3);
                  if(count($a) == 3)//je to ten spravny radek (už zas) ?
                  {
                    PrintMe($lines[$i]);
                    $j++;
                  } 
                }
                $i = -1;
                $rewind++;
              }           
              break;
            }
          }
        }
      }  
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    10.12.2009 13:13 YYY | skóre: 29 | blog: martinek
    Rozbalit Rozbalit vše Re: funkce fseek()
    Navrhoval bych nejakou peknou strukturu pro kazdy jeden den, pole ukazatelu na ty struktury(podle dni - 0-365) a pak jen podle pozadovaneho dne vypocitat index v tom poli, zobrazit a je to. Dalo by se to realizovat i jen s polem ukazatelu na char.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.