Torna indietro   Hardware Upgrade Forum > Software > Programmazione

GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
Il Gigabyte Gaming A16 offre un buon equilibrio tra prestazioni e prezzo: con Core i7-13620H e RTX 5060 Laptop garantisce gaming fluido in Full HD/1440p e supporto DLSS 4. Display 165 Hz reattivo, buona autonomia e raffreddamento efficace; peccano però le USB e la qualità cromatica del pannello. Prezzo: circa 1200€.
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-02-2012, 17:53   #1
postgres
Member
 
Iscritto dal: Apr 2008
Messaggi: 120
[PYTHON] decoratori per permessi agli attributi di una classe

Qualcuno sa come si possa attraverso i decoratori definire permessi di lettura (r), scrittura (w) ed entrambri (rw) agli attributi di una classe?

è un esercizio di università.

Il main è questo:

Codice:
traceMe = False
def trace(*args):
	if traceMe: print('[' + ' '.join(map(str, args)) + ']')
def private(*privates): # privates in enclosing scope
	def onDecorator(aClass): # aClass in enclosing scope
		class onInstance: # wrapped in instance attribute
			def __init__(self, *args, **kargs):
				self.wrapped = aClass(*args, **kargs)
			def __getattr__(self, attr): # My attrs don’t call getattr
				trace('get:', attr) # Others assumed in wrapped
				if attr in privates:
					raise TypeError('private attribute fetch: ' + attr)
				else:
					return getattr(self.wrapped, attr)
			def __setattr__(self, attr, value): # Outside accesses
				trace('set:', attr, value) # Others run normally
				if attr == 'wrapped': # Allow my attrs
					self.__dict__[attr] = value # Avoid looping
				elif attr in privates:
					raise TypeError('private attribute change: ' + attr)
				else:
					setattr(self.wrapped, attr, value) # Wrapped obj attrs
		return onInstance # Or use __dict__
	return onDecorator

from selectors import *
@private('data', 'size', 'label')
@rw(’data’)
@r(’size’)
@w(’label’)
class D:
def __init__(self, label, start):
self.label = label
self.data = start
self.size = len(self.data)
def double(self):
for i in range(self.size):
self.data[i] = self.data[i] * 2
def display(self):
print(’{0} => {1}’.format(self.label, self.data))
if __name__ == "__main__":
X = D(’X is’, [1, 2, 3])
X.display(); X.double(); X.display()
try:
print(X.size)
except Exception as e: print("{0}: {1}".format(type(e).__name__, e))
try:
print(X.data)
except Exception as e: print("{0}: {1}".format(type(e).__name__, e))
print(X.getData())
X.setData([25])
print(X.getSize())
try:
X.setSize(25)
except Exception as e: print("{0}: {1}".format(type(e).__name__, e))
try:
print(X.getLabel())
except Exception as e: print("{0}: {1}".format(type(e).__name__, e))
X.setLabel(’It has worked!!!’)
X.display()
private rende privati gli attributi.

La stampa è questa:

X is
X is => [1, 2, 3]
X is => [2, 4, 6]
TypeError: private attribute fetch: size
TypeError: private attribute fetch: data
[2, 4, 6]
1
Error: setter inexistent: setSize
Error: getter inexistent: getLabel
It has worked!!! => [25]


Forse vanno usati i setattr e i getattr come in private?
Ho provato così ma non funziona:

Codice:
def r(*r): 
	def onDecorator(aClass): 
		class onInstance: 
			def __init__(self, *args, **kargs):
				self.wrapped = aClass(*args, **kargs)
			def getdata(self, attr): 
				#trace('get:', attr) 
				if attr in rw:
					raise TypeError('getter inexistent: getsize: ' + attr)
				else:
					return getattr(self.wrapped, attr)
		return onInstance # Or use __dict__
	return onDecorator
e anche così:

Codice:
traceMe = False
def trace(*args):
	if traceMe: print('[' + ' '.join(map(str, args)) + ']')
def r(*r): # privates in enclosing scope
	def onDecorator(aClass): 
		class onInstance:
			def __init__(self, *args, **kargs):
				self.wrapped = aClass(*args, **kargs)
			def __getattr__(self, attr): 
				trace('get:', attr) 
				if attr in pr:
					raise TypeError('private attribute fetch: ' + attr)
				else:
					return getattr(self.wrapped, attr)
			def __setattr__(self, attr, value): # Outside accesses
				trace('set:', attr, value) # Others run normally
				if attr == 'wrapped': # Allow my attrs
					self.__dict__[attr] = value # Avoid looping
				elif attr in privates:
					raise TypeError('private attribute change: ' + attr)
				else:
					setattr(self.wrapped, attr, value) 
		return onInstance 
	return onDecorator
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 22-02-2012, 18:45   #2
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
L'idea dei decoratori è senz'altro corretta, come pure quella di intercettare i metodi speciali __getattr__ e __setattr__.

Comunque sistema un po' il codice iniziale, perché senza l'indentazione corretta in Python è illeggibile.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 22-02-2012, 19:04   #3
postgres
Member
 
Iscritto dal: Apr 2008
Messaggi: 120
si scusa è vero non me ne sono accorto. Ecco la seconda parte indentata

Codice:
@private('data', 'size', 'label')
#@rw('data')
@r('size')
#@w('label')

class D:
	def __init__(self, label, start):
		self.label = label
		self.data = start
		self.size = len(self.data)

	def double(self):
		for i in range(self.size):
			self.data[i] = self.data[i] * 2
	def display(self):
		print('{0} => {1}'.format(self.label, self.data))


'''
X is
X is => [1, 2, 3]
X is => [2, 4, 6]
TypeError: private attribute fetch: size
TypeError: private attribute fetch: data
[2, 4, 6]
1
Error: setter inexistent: setSize
Error: getter inexistent: getLabel
It has worked!!! => [25]
'''

if __name__ == "__main__":
	X = D('X is', [1, 2, 3])
	#X.display(); X.double(); X.display()
	try:
		print(X.size)
	except Exception as e: print("{0}: {1}".format(type(e).__name__, e))
	try:
		print(X.data)
	except Exception as e: print("{0}: {1}".format(type(e).__name__, e))
	print(X.getData())
	X.setData([25])
	print(X.getSize())
	try:
		X.setSize(25)
	except Exception as e: print("{0}: {1}".format(type(e).__name__, e))
	try:
		print(X.getLabel())
	except Exception as e: print("{0}: {1}".format(type(e).__name__, e))
	X.setLabel('It has worked!!!')
	X.display()
postgres è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2012, 07:23   #4
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Questo è un più complicato e mi richiede più tempo per l'analisi del codice e fare qualche prova.

Soltanto un paio di cose:
Codice:
from selectors import *
Questo immagino sia il modulo dove sono memorizzati gli altri 3 decoratori (r, w, rw).

Poi cosa intendi esattamente per attributo "privato"? Uno che sia accessibile soltanto tramite un metodo definito all'interno della classe stessa?

Giusto per essere chiari, supponendo che x sia definito come attributo privato:
Codice:
class c:

  def __init__(self):
    self.x = 'OK'

  def Prova(self):
    print self.x

i = c()

i.Prova() # Stampa OK, perché x è accessibile dall'interno della classe

i.x # Genera un errore, perché non ci si deve poter accedere dall'esterno
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Lapt...
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Start Cup Puglia 2025: il 16 ottobre la ...
Incentivi auto elettriche, falsa partenz...
Silence crea anche in Francia una rete d...
La realtà mista al servizio degli...
Nothing ha un altro smartphone in progra...
Decisione storica ad Amburgo: i cittadin...
Questo è il nuovo motore elettric...
HUAWEI WATCH GT 6: lo smartwatch 'infini...
Fotografia con AI: ecco Caira, la macchi...
PlayStation 6 vs Xbox Magnus: il rumor s...
DJI Osmo Action 4 a soli 208€ su Amazon:...
Irion, la data governance diventa strate...
EHang VT35: debutta in Cina il nuovo aer...
Cooler Master MasterLiquid Atmos II 360:...
Trapela in rete la roadmap dei nuovi gio...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 19:40.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v