Compare commits
6 Commits
ed29b5907c
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| fe4883cde8 | |||
| c048527f38 | |||
| 2aeaadfe18 | |||
| cc8ee1615b | |||
| 07d1e9dd75 | |||
| 722e008efa |
@@ -0,0 +1,31 @@
|
|||||||
|
from os import strerror
|
||||||
|
|
||||||
|
file_name = "lab43.txt"
|
||||||
|
|
||||||
|
# Il dizionario conterra' una coppia chiave/valore per ogni lettera trovata:
|
||||||
|
# chiave = lettera, valore = quante volte appare nel file.
|
||||||
|
letters = {}
|
||||||
|
|
||||||
|
try:
|
||||||
|
stream = open(file_name, "rt", encoding="utf-8")
|
||||||
|
|
||||||
|
ch = stream.read(1)
|
||||||
|
while ch != "":
|
||||||
|
|
||||||
|
ch = ch.lower()
|
||||||
|
|
||||||
|
if "a" <= ch <= "z":
|
||||||
|
if ch in letters:
|
||||||
|
letters[ch] += 1
|
||||||
|
else:
|
||||||
|
letters[ch] = 1
|
||||||
|
|
||||||
|
ch = stream.read(1)
|
||||||
|
|
||||||
|
stream.close()
|
||||||
|
|
||||||
|
for letter in sorted(letters.keys()):
|
||||||
|
print(letter, "->", letters[letter])
|
||||||
|
|
||||||
|
except IOError as e:
|
||||||
|
print("Errore di I/O:", strerror(e.errno))
|
||||||
@@ -0,0 +1,36 @@
|
|||||||
|
from os import strerror
|
||||||
|
|
||||||
|
|
||||||
|
file_name = "lab43.txt"
|
||||||
|
|
||||||
|
letters = {}
|
||||||
|
|
||||||
|
try:
|
||||||
|
|
||||||
|
source = open(file_name, "rt", encoding="utf-8")
|
||||||
|
|
||||||
|
ch = source.read(1)
|
||||||
|
while ch != "":
|
||||||
|
ch = ch.lower()
|
||||||
|
|
||||||
|
if "a" <= ch <= "z":
|
||||||
|
if ch in letters:
|
||||||
|
letters[ch] += 1
|
||||||
|
else:
|
||||||
|
letters[ch] = 1
|
||||||
|
|
||||||
|
ch = source.read(1)
|
||||||
|
|
||||||
|
source.close()
|
||||||
|
|
||||||
|
target = open(file_name + ".hist", "wt", encoding="utf-8")
|
||||||
|
|
||||||
|
for letter, counter in sorted(letters.items(), key=lambda item: item[1], reverse=True):
|
||||||
|
target.write(letter + " -> " + str(counter) + "\n")
|
||||||
|
|
||||||
|
target.close()
|
||||||
|
|
||||||
|
print("Istogramma salvato in:", file_name + ".hist")
|
||||||
|
|
||||||
|
except IOError as e:
|
||||||
|
print("Errore di I/O:", strerror(e.errno))
|
||||||
@@ -0,0 +1,64 @@
|
|||||||
|
from os import strerror
|
||||||
|
|
||||||
|
|
||||||
|
class StudentsDataException(Exception):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class BadLine(StudentsDataException):
|
||||||
|
def __init__(self, line_number, line):
|
||||||
|
message = "Riga " + str(line_number) + ": " + line.rstrip()
|
||||||
|
super().__init__(message)
|
||||||
|
|
||||||
|
|
||||||
|
class FileEmpty(StudentsDataException):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__("il file esiste, ma e' vuoto")
|
||||||
|
|
||||||
|
|
||||||
|
file_name = input("Inserisci il nome del file del Prof. Jekyll: ")
|
||||||
|
students = {}
|
||||||
|
|
||||||
|
try:
|
||||||
|
stream = open(file_name, "rt", encoding="utf-8")
|
||||||
|
lines = stream.readlines()
|
||||||
|
stream.close()
|
||||||
|
|
||||||
|
if len(lines) == 0:
|
||||||
|
raise FileEmpty()
|
||||||
|
|
||||||
|
for line_number, line in enumerate(lines, 1):
|
||||||
|
parts = line.split()
|
||||||
|
|
||||||
|
# Ogni riga deve avere esattamente: nome, cognome, punti.
|
||||||
|
if len(parts) != 3:
|
||||||
|
raise BadLine(line_number, line)
|
||||||
|
|
||||||
|
first_name = parts[0]
|
||||||
|
last_name = parts[1]
|
||||||
|
|
||||||
|
try:
|
||||||
|
# Accettiamo sia il punto sia la virgola come separatore decimale.
|
||||||
|
points = float(parts[2].replace(",", "."))
|
||||||
|
except ValueError:
|
||||||
|
raise BadLine(line_number, line)
|
||||||
|
|
||||||
|
student = first_name + " " + last_name
|
||||||
|
|
||||||
|
if student in students:
|
||||||
|
students[student] += points
|
||||||
|
else:
|
||||||
|
students[student] = points
|
||||||
|
|
||||||
|
if len(students) == 0:
|
||||||
|
raise FileEmpty()
|
||||||
|
|
||||||
|
for student in sorted(students.keys()):
|
||||||
|
print(student, students[student])
|
||||||
|
|
||||||
|
except FileEmpty as e:
|
||||||
|
print("Errore:", e)
|
||||||
|
except BadLine as e:
|
||||||
|
print("Errore nei dati di input:", e)
|
||||||
|
except IOError as e:
|
||||||
|
print("Errore di I/O:", strerror(e.errno))
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
John Smith 5
|
||||||
|
Anna Bolena 4,5
|
||||||
|
John Smith 2
|
||||||
|
Anna Bolena 11
|
||||||
|
Andrew Cox 1,5
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
def find(path, dir):
|
||||||
|
if not os.path.isdir(path):
|
||||||
|
return
|
||||||
|
|
||||||
|
for name in os.listdir(path):
|
||||||
|
full_path = os.path.join(path, name)
|
||||||
|
|
||||||
|
if os.path.isdir(full_path):
|
||||||
|
if name == dir:
|
||||||
|
print(os.path.abspath(full_path))
|
||||||
|
|
||||||
|
find(full_path, dir)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
start_path = input("Percorso di partenza: ")
|
||||||
|
directory_name = input("Directory da cercare: ")
|
||||||
|
|
||||||
|
find(start_path, directory_name)
|
||||||
@@ -0,0 +1,28 @@
|
|||||||
|
from datetime import datetime
|
||||||
|
|
||||||
|
d = datetime(year=2020, month=11, day=4, hour=14, minute=53, second=0)
|
||||||
|
|
||||||
|
# Direttive usate con strftime:
|
||||||
|
# %Y anno con 4 cifre -> 2020
|
||||||
|
# %y anno con 2 cifre -> 20
|
||||||
|
# %m mese numerico -> 11
|
||||||
|
# %B nome mese completo -> November
|
||||||
|
# %b nome mese abbreviato -> Nov
|
||||||
|
# %d giorno del mese -> 04
|
||||||
|
# %H ora formato 24h -> 14
|
||||||
|
# %M minuti -> 53
|
||||||
|
# %S secondi -> 00
|
||||||
|
# %p AM/PM -> PM
|
||||||
|
# %a giorno abbreviato -> Wed
|
||||||
|
# %A giorno completo -> Wednesday
|
||||||
|
# %w giorno settimana -> 3
|
||||||
|
# %j giorno dell'anno -> 309
|
||||||
|
# %W numero settimana -> 44
|
||||||
|
|
||||||
|
print(d.strftime("%Y/%m/%d %H:%M:%S"))
|
||||||
|
print(d.strftime("%y/%B/%d %H:%M:%S %p"))
|
||||||
|
print(d.strftime("%a, %Y %b %d"))
|
||||||
|
print(d.strftime("%A, %Y %B %d"))
|
||||||
|
print(d.strftime("Weekday: %w"))
|
||||||
|
print(d.strftime("Day of the year: %j"))
|
||||||
|
print(d.strftime("Week number of the year: %W"))
|
||||||
@@ -0,0 +1,29 @@
|
|||||||
|
from calendar import Calendar
|
||||||
|
|
||||||
|
class MyCalendar(Calendar):
|
||||||
|
|
||||||
|
def count_weekday_in_year(self, year, weekday):
|
||||||
|
|
||||||
|
count = 0
|
||||||
|
|
||||||
|
for month in range(1, 13):
|
||||||
|
|
||||||
|
month_calendar = self.monthdays2calendar(year, month)
|
||||||
|
|
||||||
|
for week in month_calendar:
|
||||||
|
|
||||||
|
for day_number, day_weekday in week:
|
||||||
|
|
||||||
|
if day_number != 0 and day_weekday == weekday:
|
||||||
|
count += 1
|
||||||
|
|
||||||
|
return count
|
||||||
|
|
||||||
|
|
||||||
|
my_calendar = MyCalendar()
|
||||||
|
|
||||||
|
|
||||||
|
result = my_calendar.count_weekday_in_year(2000, 6)
|
||||||
|
|
||||||
|
|
||||||
|
print(result)
|
||||||
Reference in New Issue
Block a user