Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
K
kurs_alx_pcz
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Patryk Czarnik
kurs_alx_pcz
Commits
8e4128d2
Commit
8e4128d2
authored
Nov 29, 2023
by
Patryk Czarnik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
policz jedno słowo
parent
19e067d2
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
51 additions
and
6 deletions
+51
-6
policz_jedno_slowo1.py
dzien4/pliki/policz_jedno_slowo1.py
+15
-0
policz_jedno_slowo2.py
dzien4/pliki/policz_jedno_slowo2.py
+16
-0
policz_jedno_slowo_male_litery.py
dzien4/pliki/policz_jedno_slowo_male_litery.py
+14
-0
wypisz_slowa2.py
dzien4/pliki/wypisz_slowa2.py
+6
-6
No files found.
dzien4/pliki/policz_jedno_slowo1.py
0 → 100644
View file @
8e4128d2
# Użytkownik podaje jakieś słowo
# a program oblicza ile razy to słowo występuje w pliku pan-tadeusz.txt
import
re
szukane
=
input
(
'Podaj szukane słowo: '
)
pattern
=
re
.
compile
(
r'\w+'
)
nr
=
0
with
open
(
'pan_tadeusz.txt'
,
mode
=
'r'
,
encoding
=
'utf-8'
)
as
plik
:
for
linia
in
plik
:
for
slowo
in
re
.
findall
(
pattern
,
linia
):
if
slowo
==
szukane
:
nr
+=
1
print
(
f
'Szukane słowo {szukane} występuje {nr} razy.'
)
dzien4/pliki/policz_jedno_slowo2.py
0 → 100644
View file @
8e4128d2
# W tej wersji szukane słowo umieszczamy w wyrażeniu regularnym.
# Aby powiedzieć, że ma być to całe słowo, umieszczamy między znacznikiem \b oznaczającym "granicę słów"
# Aby znaki specjalne wprowadzone przez usera utraciły swoje specjalne znaczenie, korzystamy z funkcji escape
# (zasada przypominająca zapobieganie SQL injection).
import
re
szukane
=
input
(
'Podaj szukane słowo: '
)
pattern
=
re
.
compile
(
r'\b'
+
re
.
escape
(
szukane
)
+
r'\b'
)
nr
=
0
with
open
(
'pan_tadeusz.txt'
,
mode
=
'r'
,
encoding
=
'utf-8'
)
as
plik
:
for
linia
in
plik
:
for
slowo
in
re
.
findall
(
pattern
,
linia
):
nr
+=
1
print
(
f
'Szukane słowo {szukane} występuje {nr} razy.'
)
dzien4/pliki/policz_jedno_slowo_male_litery.py
0 → 100644
View file @
8e4128d2
# Wersja, która nie rozróżnia małych / dużych liter
import
re
szukane
=
input
(
'Podaj szukane słowo: '
)
.
lower
()
pattern
=
re
.
compile
(
r'\w+'
)
nr
=
0
with
open
(
'pan_tadeusz.txt'
,
mode
=
'r'
,
encoding
=
'utf-8'
)
as
plik
:
for
linia
in
plik
:
for
slowo
in
re
.
findall
(
pattern
,
linia
):
if
slowo
.
lower
()
==
szukane
:
nr
+=
1
print
(
f
'Szukane słowo {szukane} występuje {nr} razy.'
)
dzien4/pliki/wypisz_slowa2.py
View file @
8e4128d2
# W tej wersji do podziału każdej linii na słowa wykorzystamy wyrażenia regularne.
# Teoretycznie można by wczytać cał
u
y plik za pomocą read() i dopiero podzielić na słowa,
# ale zwn wydajność prefer
e
ujemy przetwarzanie linia za linią, stąd dwupoziomowa pętla.
# Również zwn na wydajność lepiej jest najpierw "skompilować" wyrażenie regularne, a później używać wersji skompilowan
je
, tzw. "patternu".
# Dotyczy to sytuacji, gdy to samo wyraż
ne
ie jest używane wielokrotnie, np. w pętli.
# Teoretycznie można by wczytać cały plik za pomocą read() i dopiero podzielić na słowa,
# ale zwn wydajność preferujemy przetwarzanie linia za linią, stąd dwupoziomowa pętla.
# Również zwn na wydajność lepiej jest najpierw "skompilować" wyrażenie regularne, a później używać wersji skompilowan
ej
, tzw. "patternu".
# Dotyczy to sytuacji, gdy to samo wyraż
en
ie jest używane wielokrotnie, np. w pętli.
import
re
# znaczenie wzorca: nieputy ciąg znaków typu 'w', co obejmuje litery (wszelkich alfabetów), cyfry i znak _
# znaczenie wzorca: niepu
s
ty ciąg znaków typu 'w', co obejmuje litery (wszelkich alfabetów), cyfry i znak _
pattern
=
re
.
compile
(
r'\w+'
)
nr
=
0
with
open
(
'pan_tadeusz.txt'
,
mode
=
'r'
,
encoding
=
'utf-8'
)
as
plik
:
for
linia
in
plik
:
for
slowo
in
re
.
findall
(
pattern
,
linia
):
# albo: for slowo in pattern.findall(linia):
for
slowo
in
re
.
findall
(
pattern
,
linia
):
# albo: for slowo in pattern.findall(linia):
nr
+=
1
print
(
slowo
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment