Не получен ожидаемый результат с использованием дескриптора в Python - PullRequest
1 голос
/ 23 марта 2019

Я новичок в Python ... пробовал какой-то код с дескриптором и выполнял код ниже, чтобы изменить Фаренгейт на Цельсий. Но я не получаю точный результат. Может кто-нибудь помочь, как это работает?

Попробовал ниже код

import sys
import os

class Celsius:
    def __get__(self, obj, owner):
        return self.celsius

    def __set__(self, obj, value):
        self.celsius = (value-32)*5/9

class Temperature:
    celsius = Celsius()

    def __init__(self, f):
        self.fahrenheit = f

t1 = Temperature(32)
t1.celsius = 0

if __name__ == "__main__":
        t1 = Temperature(int(input()))
        print(t1.fahrenheit, t1.celsius)

Ожидаемый результат: (212, 100,0) (согласно формуле) фактический результат: (212, -17,77777777777778) Как рассчитывается -17?

Ответы [ 3 ]

0 голосов
/ 23 марта 2019

Вы не должны инициализировать t1.celsius с 0, а вместо этого использовать установщик celsius в Temperature.__init__:

class Temperature:
    celsius = Celsius()

    def __init__(self, f):
        self.fahrenheit = self.celsius = f

Демо: https://repl.it/repls/UsableSunnyConfig

0 голосов
/ 23 марта 2019

Вот простой менеджер температуры, который обрабатывает диалоги: Кельвин, Фаренгейт, Цельсий

class Temperature:
    def __init__(self, value, unit='C'):
        self.value = value
        if unit.upper() in ['C', 'F', 'K']:
            self.unit = unit.upper()
        else:
            raise ValueError('Unit must be C|F|K')

    @property
    def kelvin(self):
        if self.unit == 'K':
            return self.value
        elif self.unit == 'C':
            return self.value - 273.15
        else:
            return (self.value - 273.15) * 9 / 5 + 32

    @property
    def celsius(self):
        if self.unit == 'C':
            return self.value
        elif self.unit == 'K':
            return self.value + 273.15
        else:
            return (self.value * 9 / 5) + 32

    @property
    def fahrenheit(self):
        if self.unit == 'F':
            return self.value
        elif self.unit == 'C':
            return (self.value - 32) * 5 / 9
        else:
            return (self.value - 32) * 5 / 9 + 273.15


t = Temperature(7,'k')
print(t.fahrenheit)
0 голосов
/ 23 марта 2019
t1.celsius = 0

Это твоя ошибка. Вы создаете класс Цельсия с нулевым значением, поэтому установщик устанавливает (0 - 32) * 5/9, то есть - 17.777777777778

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...