8. Gyakorlat AWK 1, CSS

Hasonló dokumentumok
Operációs rendszerek. 11. gyakorlat. AWK - szintaxis, vezérlési szerkezetek UNIVERSITAS SCIENTIARUM SZEGEDIENSIS UNIVERSITY OF SZEGED

AWK programozás, minták, vezérlési szerkezetek

Informatika 1 CSS. Kovács Kristóf, Pálovics Róbert, Wettl Ferenc november 4. Budapesti M szaki Egyetem

AWK programozás, minták, vezérlési szerkezetek

Operációs rendszerek. 10. gyakorlat. AWK - bevezetés UNIVERSITAS SCIENTIARUM SZEGEDIENSIS UNIVERSITY OF SZEGED

AWK programozás Bevezetés

Multimédia 2017/2018 II.

BASH SCRIPT SHELL JEGYZETEK

Informatika 1. Informatika el adás. Kovács Kristóf, Pálovics Róbert. Budapesti M szaki Egyetem november 13.

HTML sablon tervezése

HTML ÉS PHP ŐSZI FÉLÉV

WCSS (Wap CSS), Wireless CSS

Operációs rendszerek gyak.

1. Alapok. #!/bin/bash

Tili-Toli játék. Felhasználói dokumentáció

length (s): Az s karaklerlánc hossza, substr(s,m,n): Az s mezőben levő karakterláncnak az m-edik karakterétől kezdődő, n darab karaktert vágja ki.

Web programozás. 3. előadás

S z á m í t ó g é p e s a l a p i s m e r e t e k

Memória játék. Felhasználói dokumentáció

5-ös lottó játék. Felhasználói dokumentáció

Tamás Ferenc: CSS táblázatok 2.

HTML kódok. A www jelentése World Wide Web.

HTML és CSS. Horváth Árpád május 6. Óbudai Egyetem Alba Regia M szaki Kar (AMK) Székesfehérvár

CSS3 alapismeretek. Bevezetés a CSS-be. Mi is az a CSS? Alkalmazási formái, szintaxisa

Webszerkesztés stílusosan. Készítette: Csécsy László Virgina DeBolt hasonló c. könyve alapján

Weblap készítése. Fapados módszer

Webprogramozás szakkör

Sakk játék. Feladat: JavaScript segítségével olyan programot kell írni, ami egy sakktáblát szimulál. Kiválasztásra változtatják a helyüket.

Szkriptnyelvek. 1. UNIX shell

Számológép. Bármilyen számítógépen működik, amin található böngésző és Java alkalmazás. Indító képernyő

Rendszerprogramozás Linux környezetben

HTML alapok. A HTML az Internetes oldalak nyelve.

(statikus) HTML (XHTML) oldalak, stíluslapok

3. modul - Szövegszerkesztés

Stíluslapok használata (CSS)

HTML kódolás Web-lap felépítése. Az egész törzsre érvényes utasítás. <HTML> web-lap kezdő utasítás: a dokumentum kezdődik, a böngészőnek szól

Operációs Rendszerek II. labor. 2. alkalom

Webprogramozás HTML alapok előadás

HTML parancsok (html tanfolyam témakörei)

Szűrők, reguláris kifejezések AWK programozás: minták, vezérlési szerkezetek, tömbök, beépített függvények, reguláris kifejezések

Szűrők Reguláris kifejezések, AWK

(statikus) HTML (XHTML) oldalak, stíluslapok


file./script.sh > Bourne-Again shell script text executable << tartalmat néz >>

Operációs rendszerek 2 3. alkalom - Reguláris kifejezések, grep, sed. Windisch Gergely windisch.gergely@nik.uni-obuda.hu

Internet, Az internet főbb szolgáltatásai web keresőszolgáltatásokkal Keresőrendszerek: Kulcsszavas 2) Egyéb keresők: Metakeresők gyűjtőkörű keresők

Kelda WebGrafika Iroda Példa HTML, CSS formázásra

HTML. Dr. Nyéki Lajos 2016

Kövér betűk (bold) 1-es fejléc

Az image objektum. Az image eseménykezel i. Képek el zetes betöltése. Feladat. Váltóképek készítése

ÁLTALÁNOS WEBLAPSZERKESZTÉSI TUDNIVALÓK ÁLTALÁNOS HTML KÓDOLÁSI TUDNIVALÓK

Algoritmus terv. 1. Algoritmus általános áttekintése. 2. Inputok és outputok definiálása. 3. Folyamatok meghatározása. 4. Programozási utasítások

Megoldás (HTML) <!DOCTYPE HTML> <html>

Táblázatok. Utolsó módosítás: 11/22/ :07:23

BASH script programozás II. Vezérlési szerkezetek

A HTML Stuktúra. 1. oldal, összesen: 8 oldal. mhtml:file://d:\vizsga\1\html kódok.mht. Betűtípusok, stílusok <b> <i> <u> <tt>

INFO1 WEB, HTML, CSS

2. Készítsen awk szkriptet, amely kiírja az aktuális könyvtár összes alkönyvtárának nevét, amely februári keltezésű (bármely év).

Képek a HTML oldalon

ECDL Táblázatkezelés A táblázatkezelés első lépései Beállítások elvégzése

Lekérdezések az SQL SELECT utasítással

Képnézeget. Gépigény: Bármilyen számítógépen m ködik, amin található böngész és Internet elérés.

Responsive Web Design. Dr. Nyéki Lajos 2019

Járműfedélzeti rendszerek II. 1. előadás Dr. Bécsi Tamás

Webprogramozás szakkör

II. Mérés SZÉCHENYI ISTVÁN EGYETEM GYŐR TÁVKÖZLÉSI TANSZÉK

Programozás alapjai gyakorlat. 2. gyakorlat C alapok

Alapok. tisztán funkcionális nyelv, minden függvény (a konstansok is) nincsenek hagyományos változók, az első értékadás után nem módosíthatók

Programozás alapjai gyakorlat. 4. gyakorlat Konstansok, tömbök, stringek

Munka állományokkal. mv: áthelyezés (átnevezés) rm: törlés. rmdir: üres könyvtár törlése. -r, -R: rekurzív (könyvtár) -r, -R: rekurzív (könyvtár)

8. Mezőutasítások. Schulcz Róbert 8. Mezőutasítások. v

Az MS Word szövegszerkesztés modul részletes tematika listája


HTML, XML szerkesztés

HTML alapok 1. Minimális HTML file: <HTML> <HEAD> <TITLE> cím </TITLE> </HEAD> <BODY>... </BODY> </HTML> Formátum parancsok:

6. BASH programozás I.

PHP. Telepítése: Indítás/újraindítás/leállítás: Beállítások: A PHP nyelv

Operációs rendszerek gyak.

Lenyíló menük készítése. Összetett programok készítése

vi CSS zsebkönyv Alapvetõ képi elrendezés Tömbszerû elrendezés Szövegközi elrendezés

WEB TECHNOLÓGIÁK 3.ELŐADÁS

Operációs rendszerek. 2. gyakorlat. Munka állományokkal UNIVERSITAS SCIENTIARUM SZEGEDIENSIS UNIVERSITY OF SZEGED

10. gyakorlat Struktúrák, uniók, típusdefiníciók

Sakk-játék. Bármilyen számítógépen működik, amin található böngésző és Java alkalmazás. Indító képernyő

7. Laboratóriumi gyakorlat: Vezérlési szerkezetek II.

ELTE SAP Excellence Center Oktatóanyag 1

chmod umask chown, chgrp

Tájékoztató. Használható segédeszköz: -

A C programozási nyelv I. Bevezetés

7. Laboratóriumi gyakorlat, 1. rész : Vezérlési szerkezetek II.

A C programozási nyelv I. Bevezetés

BEKÉRT ADAT KÉPERNYŐRE ÍRÁSA KÖRNYEZETI VÁLTOZÓK FÁJL REDEZETT KIÍRÁSA KÖNYVTÁRBAN BEJEGYZÉSEK SZÁMA FÁJLBAN SZÁM NÖVELÉSE. #!

Karakterkészlet. A kis- és nagybetűk nem különböznek, a sztringliterálok belsejét leszámítva!

A függvény kód szekvenciáját kapcsos zárójelek közt definiáljuk, a { } -ek közti részt a Bash héj kód blokknak (code block) nevezi.

Bevezetés a programozásba I 4. gyakorlat. PLanG: Szekvenciális fájlkezelés. Szekvenciális fájlkezelés Fájlok használata

A C# programozási nyelv alapjai

PHP alapjai, bevezetés. Vincze Dávid Miskolci Egyetem, IIT

3. modul - Szövegszerkesztés

Munka állományokkal, könyvtárakkal I.

I/1. Pályázati adatlap

Átírás:

8. Gyakorlat AWK 1, CSS

Az awk egy általános célú programozási nyelv, amelyet szöveges állományok földolgozására terveztek. Elnevezése a megalkotói Alfred Aho, Peter Weinberger és Brian Kernighan családnevének kezdőiből született. Ideális szöveges állományok szűrésére, átformálására, kiértékelésére. Ma is minden unix rendszeren van legalább egy awk változat. A Free Software Foundation a gawk nevű változatot gondozza. A linux disztribúciókkal jellemzően a gawk implementációt szállítják. Windows rendszerekhez is letölthető a gawk például a Cygwin részeként.

program grep sed leírás soronként végignézi a fájlokat és a mintával egyező sorokat keres kapcsolókkal, opciókkal lehet a működését befolyásolni szerzője: Lee McMahon (sed=stream editor) programozható szövegszerkesztő, amely egybetűs parancsok és szabályos kifejezések segítségével vezérelhető a mintát és a tevékenységet is általánosítja vesz egy (szerkesztőparancsokból összeállított) "programot" és a fájl minden sorára végrehajtja awk C jellegű programnyelv (néhány szerkezet hiányzik belőle, mások pedig eltérnek tőle ) kevésbé alkalmas a szöveg átalakítására, mint a sed tartalmaz aritmetikai műveleteket, változókat, beépített függvényeket

$ awk program fájlnevek $ awk -f parancsfájl fájlnevek $ kimenet awk Egy tipikus awk program a végrehajtása során a bemeneti adatokat egy másféle kimenetté formálja át. A programok általában mintából és a mintához tartozó parancsokból állnak:

a program az alábbiakból áll: minta (tevékenység) minta (tevékenység) Az awk soronként olvassa a bemenetet. Minden beolvasott sort összehasonlít a mintákkal, és ha illeszkedést talál, a parancsokat végrehajtja. A mintákat a szabályos (reguláris) kifejezések szabályai szerint értelmezi. A bemeneti fájlokat nem változtatja meg. A tevékenység rész egy C szerű utasítás(blokk).

BEGIN { parancs(ok) adatbeolvasás előtt ezeket a parancsokat végrehajtja { minta (tevékenység) END { parancs(ok) adatbeolvasás és a többi parancs végrehajtása után ezeket a parancsokat végrehajtja

awk /regularis kifejezés/ fájlnevek kiírja a mintára illeszkedő sorokat. awk (print) fajlnevek kiírja a fájl(oka)t (minden sort) Tulajdonképpen ugyanazt csinálja, mint a cat, de sokkal lassabban. awk -f parancsfájl fájlnevek Az awk parancsnak is megadhatjuk a programot fájlból. Ebben az esetben a f opciót szükséges használni parancsfájl első sorába be kell írni: #! /bin/awk

Az awk minden bemenő sort mezőkre bont. mező: szóközökkel, vagy tabulátorokkal elválasztott, szóközt nem tartalmazó karakterlánc. mezőelválasztó: (default) az awk a fehér (üres) karaktereket (szóköz, tabulátor)tekinti, de meg lehet adni neki valamely más karaktert (de csak 1 karaktert!) is mezőelválasztónak (FS).

$ awk -F: {print $2 /etc/passwd $ awk BEGIN {FS=":" {print $2 /etc/passwd a beolvasott minden sor mezőit rendre az 1,2,3,., NF változóba teszi. ha a mezők tartalmára szeretnénk hivatkozni, akkor azt, a $1, $2,... tehetjük meg $NF: az aktuális sor utolsó mezőjének értékét tartalmazza, $0: az aktuális teljes sort tartalmazza,

az awk esetén a shellel ellentétben csak a mezők neve elé kell $ jelet tenni, ha annak tartalmára szeretnénk hivatkozni. $ who awk {print $3, $4, $5, $1, $2

Változó FILENAME NF NR FS RS OFS ORS OFMT Jelentése az aktuális bemeneti fájl neve bemeneti rekord (sor) mezőszáma bemeneti rekordok száma mezőelválasztó karakter (default: tab és space) bemeneti rekordelválasztó karakter kimenő mezőelválasztó karakter/lánc/ (default. szóköz) kimeneti rekordelválasztó karakter/lánc/ (default: újsor) kimenő számok formátuma (default: %g lásd printf(3)) $0 a feldolgozás alatt álló egész sor $1, $2, $n a sor egyes, egymástól szóközzel elválasztott részei.

Az NF tehát az aktuális sor mezőszámát adja meg, a $NF pedig az aktuális sor utolsó mezőjének értékét. A shell script-ben és az awk-ban is vannak beépített változók ($0, $1, $2, ) de ezek különbözőek, mást jelentenek!!!

$ awk '{print NR, $0' lista kiírja a lista állomány tartalmát, úgy, hogy a sorokat számozza $ cat lista awk '{print NR, $0'

$ who awk BEGIN {OFS= @ {print NR,$2,$3,$4 BEGIN { OFS= @ { print NR, $2, $3, $4 az egyes sorokat sorszámozva írja ki, a sorokból csak a 2., 3., 4. mezőt írja ki, és a mezőelválasztó karakter @ lesz

$ awk 'BEGIN { OFMT = "%.0f" # print numbers as integers (rounds) print 17.23, 17.54 17 18

A printf utasítással formázott kiíratást valósíthatunk meg. Ez olyan, mint a C nyelv ilyen nevü függvénye. $ awk {printf "%4d %s\n", NR, $0 file002

A változókat azzal definiáljuk, hogy használni kezdjük. Alapértelmezés szerint a változók kezdőértéke 0, így nem kell törődnünk az inicializálásukkal. Aritmetikai műveletek elvégzése is könnyebb, mint az expr shell parancs.

Az awk változói karakterláncokat is tárolhatnak A szövegösszefüggéstől is függ, hogy a változót numerikus vagy sztring típusú változóként kezeli-e a program. s = s +1 számértéket használ a program s= abc karakterérték x>y karakterértéket használ, kivéve, ha az oparandusok nyilvánvalóan numerikusak Az awk-ban használhatók a C nyelvben használatos aritmetikai rövidítéseket is: s += $1; s = s + $1;

# ls awk {print NR,$0 > lista1 $ awk {s = s + $1 END {print s lista1 az első oszlop számainak összegzése $ awk {s = s + $1 END {print s/nr lista1 az első oszlop számainak átlaga $ wc lista awk {print $3/$1 egy fájl átlagos soronkénti karaktereinek száma

{ nc += length($0)+1 nw += NF END {print NR, nw, nc

Operátor =, +=, -=, *=, /=, %= Hatása értékadás (v op=kif ugyanaz. mint v = v op (kif)) vagy/or/ (k I II k2 igaz. ha valamelyik igaz; k2-t nem értékeli, ha k1 igaz) &&! negálás >, >=, <, <=, ==,!=, ~,! ~ semmi és/and (k1 && k2 igaz, ha mindkettő igaz; k2-t nem értékeli. ha k1 hamis) relációs operátorok karakterlánc összekapcsolása +,- összeadás, kivonás *,/, % szorzás, osztás, maradék ++, -- Növelés, csökkentés (elöl vagy hátul)

$1 == az 1. mező üres $1 ~ /^$/ az 1. mező megegyezik az üres karakterlánccal $1!~ /./ az 1. mező semmilyen karakterrel nem egyezik meg length($1) == 0 az 1. mező hossza nulla ~ reguláris kifejezés egyezése!~ reguláris kifejezés nem egyezése/különbözősége! minta tagadása!($1 == ) NF % 2!= 0 páratlan számú mező van length($0) > 25 a sor hossza 25 karakternél hosszabb

A BEGIN utáni tevékenységet az awk parancs az első bemenő sor beolvasása előtt hajta végre. Használhatjuk: -változó inicializálásra -mezőelválasztó karakter meghatározására -fejléc nyomtatására awk 'BEGIN (FS= : (print $2) /etc/passwd

Az END utáni tevékenységeket az awk a bemenet utolsó sorának feldolgozása után hajtja végre. $ awk END (print NR ) lista kiírja a lista állomány sorainak számát

#! /bin/awk BEGIN { print "eleje" { print "cucc" END { print "vége" awk -f program

SU 01/30 13:15 - ttyq1 jose-root #! /bin/awk SU 01/30 13:15 + ttyq1 jose-root # works for Solaris, IRIX and HPUX 10.20 BEGIN { print "--- checking sulog" failed=0 { if ($4 == "-") { print "failed su:\t"$6"\tat\t"$2"\t"$3 failed=failed+1 END { print "------------------------------------- --" printf("\ttotal number of records:\t%d\n", NR) printf("\ttotal number of failed su's:\t%d\n",failed)

A CSS (angolul Cascading Style Sheets) a számítástechnika egyik stílusleíró nyelve, amely a HTML vagy XHTML dokumentumok megjelenését írja le. A CSS-t a html, xhtml dokumentumokban arra használják, hogy a lapok színét, hátterét, betűtípusait, elrendezéseit stb. beállítsák.

A CSS bevezetésével elkülönítették a dokumentumok struktúráját a megjelenéstől, így a weblapok használhatóbbak, kezelhetőbbek, egyszerűbbek lettek, ugyanis a CSS használatával a kódból eltűntek egyebek között a karakterformázó tag-ek. A CSS ugyancsak alkalmas arra, hogy a dokumentum stílusát a megjelenítési módszer függvényében adja meg, így elkülöníthető a dokumentum formája a képernyőn, a nyomtatási lapon, a hangos böngészőben (amely beszédszintetizátor segítségével olvassa fel a weblapok szövegét), vagy braille készüléken megjelenítve.

a dokumentumszerkezet megváltoztatása nélkül lehet befolyásolni a megjelenést és az elrendezést <STYLE> </STYLE> fejrészbe kerül, mivel nem képez semmiféle kimenetet szabályok halmaza <style TYPE= text / css > B, H2, H4 {color: green; font-size: 13px; text-align: center; </style>

Szabályok részei: a HTML elem neve, melyre a szabály vonatkozik egy vagy több tulajdonságnévből (ez itt a color) a tulajdonsághoz tartozó értékből (green) Egyedi szabályok készítése: <styletype= text / css > #stilus1 {color: green; body {background-color: #7EEF00; </style> <p ID= stilus1 >Ez az első stíluslapom</p>

Stíluslapokkal befolyásolható tulajdonságok: Térköz Színek Betűtípusok Margók, keretek

Szöveg igazítása letter-spacing: betűk közötti távolság megadása text-decoration: vonalakat helyezhetünk el a szöveg alatt, felett, vagy a szöveg belsejében text-align: a szöveg igazítását határozhatjuk meg vele vertical-align: feljebb, vagy lejjebb tolhatjuk az elemeket a vele egy sorban elhelyezett elemekhez képes text-transform: kis és nagybetűk használatát szabályozza line-height: az aktuális sor teteje és a következő sor teteje közötti távolságot állíthatjuk be segítségével háttérszíneket és háttérképeket color: egy elem szövegének színét határozhatjuk meg vele background-color: egy elem háttérszínét határozza meg background-image: az elem hátteréül használt háttérkép kiválasztására szolgál background: gyors megoldást kínál az előbb felsorolt háttérbeállítások meghatározására

betűtípusok font-style: a betűkészlet stílusát határozza meg font-family: a szöveg betűtípusát határozhatjuk meg segítségével font-variant: a normal érték a kisbetűket a hagyományos módon, a small caps érték pedig kiskapitális formájában jeleníti meg font-size: a betűkészlet pontmérete font-weight: a szöveg vastagságát határozhatjuk meg általános elrendezés margin: ugyanazt azt értéket rendeli mind a négy margószélességhez width: egy elem szélességét határozza meg height: egy elem magasságát határozza meg float: egy elem szöveggel történő körbefuttatására szolgál clear: ezzel a tulajdonsággal fejezhetjük be az elemek szövegekkel történő körbefuttatását

Mértékegységek használata stíluslapoknál px: képpont; a számítógép kijelzőjének és más eszközöknek a legkisebb megcímezhető egységei pt: pont; a betűkészletek méretének szabványos mértékegysége ex: az x karakter hozzávetőleges magassága az adott betűkészletben Külső stíluslapok használata Dokumentum átláthatósága érdekében <link REL=STYLESHEET TYPE= text/css HREF= index.css >

Előfordul olyan eset, amikor egy felsorolásban nem minden elemre kell linket tennünk, de azoknak különbözniük kell a felsorolás többi elemének színétől stb. Nézzük a CSS-t:

li { font-size:12px; font-family:'courier new'; color:red; li a:link, li a:visited{ font-size:12px; font-family:'courier new'; color:blue; text-decoration:none; li a:hover{ font-size:12px; font-family:'courier new'; color:blue; text-decoration:underline;

Html: <ul> <li>nem link</li> <li><a href="#">link</a></li> <li>nem link</li> <li><a href="#">link</a></li> <li>nem link</li> <li><a href="#">link</a></li> </ul>

Az id-kat # prefix-szel a classokat pedig. prefix-szel látjuk el CSS-ben. li { font-size:12px; font-family:'courier new'; color:red;. class{ font-size:12px; font-family:'courier new'; color:blue; #id{ font-size:12px; font-family:'courier new'; color:black;

Html kód: <ul> <li>normál lista elem</li> <li id="id">id</li> <li class="class">class</li> </ul>

Belső Figyelem: ilyenkor a CSS-t <style></style> tag-ek közé kell tennünk Külső Ilyenkor a CSS fájlban nem kell a tartalmat <style></style> tag közé tenni.

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <style type="text/css"> #r { background-color: "gray"; color: "white"; body { background-color: #7EEF00; select { background-color: "red"; color: "yellow";

hr { border-top: 1px dashed; color: #9D9D96; height: 0px; width: 400px; table { width: 690px; align: center; background-color: #9EFF90; td { text-align: left;

td.adat { font-size: 12px; width: 405px; color: #6C665C; font-family: 'Trebuchet MS', Tahoma, sans-serif; text-align: center; p.left_title { width: 180px; font-size: 13px; font-family: 'Trebuchet MS', Tahoma, sans-serif; color: #C56252;.style3 { font-family: bookman; color: #243D51;

a:link { color: #243D51; text-decoration: none; font-size: 10px; a:visited { color: #243D51; text-decoration: none; font-size: 16px;

a:hover { color: #243D51; text-decoration: none; font-size: 16px; img { margin: 10; border-width: 10; </style> </head>

<body> <input name="klubtag_szam1" id="r" type="text" size="15" maxlength=15><br> <select> <option>1</option> <option>2</option> </select> <table border="1"> <tr> <td class="adat">gfdsh</td> </tr> </table> <hr> <br> <a href="borospince.hu">linkem</a><br> <img src="button_belep.gif"> </body> </html>

<head> <link REL=STYLESHEET TYPE="text/css" HREF="css/index.css"> </head>