[Tutor] Beginner problem: name 'convertToFahrenheit' is not defined

Joseph Bae joeturf at gmail.com
Sat Aug 16 07:24:38 CEST 2008


Sorry! I copied the sample output from my command prompt incorrectly.

Correct sample output:

Enter A Number : 50
Convert to (F)ahrenheit or (C)elsius? C
50 Fahrenheit = 32 Celsius
*50 *(not 32) Celsius = 147 Fahrenheit

Joe

On Fri, Aug 15, 2008 at 10:22 PM, Joseph Bae <joeturf at gmail.com> wrote:

> Thanks for the help!
>
> I have managed to get a good temperature converter program working! I am
> working on beefing it up a bit with some exception handling and an "and-or
> trick". The error handling works okay but I am having problems using and-or.
> Here's my updated code:
>
> def main():
>     true = 1
>     while true:
>         try:
>             temp = int(raw_input("Enter A Number : "))
>             break
>         except ValueError:
>             print "Invalid Input"
>     while true:
>         convertTo = raw_input("Convert To (F)ahrenheit or (C)elsius? : ")
>         if not convertTo == "F" and not convertTo == "C":
>             print "Invalid Input"
> *        else:
>             convertTo == "C" and convertToCelsius(temp) or
> convertToFahrenheit(temp)
>             break
> *
> def convertToCelsius(t):
>     tC = (9.0/5.0) * (t - 32)
>     print "%d Fahrenheit = %d Celsius" % (t, tC)
>
> def convertToFahrenheit(t):
>     tF = (9.0/5.0) * (t + 32)
>     print "%d Celsius = %d Fahrenheit" % (t, tF)
>
> if __name__=="__main__":
>     main()
>
> Sample Output (as of right now):
>
> Enter A Number : 50
> Convert to (F)ahrenheit or (C)elsius? C
> 50 Fahrenheit = 32 Celsius
> 32 Celsius = 147 Fahrenheit <-- shouldn't show up and 147 is too high ...
>
> This only happens when I tell it to convert to C, if I say F it works
> normally. I've debugged it with pdb.set_trace() many times but can't figure
> out what's wrong. Help is much appreciated =)
>
> Thanks,
>
> Joe
>
>
> On Thu, Aug 14, 2008 at 10:50 PM, Alan Gauld <alan.gauld at btinternet.com>wrote:
>
>> "Joseph Bae" <joeturf at gmail.com> wrote
>>
>>  temp = input("Enter A Number : ")
>>> convertTo = raw_input("Convert To (F)ahrenheit or (C)elsius? : ")
>>>
>>> if convertTo == "F":
>>>   convertedTemp = convertToFahrenheit(temp)
>>>   print "%d Celsius = %d Fahrenheit" % (temp, convertedTemp)
>>> else:
>>>   convertedTemp = convertToCelsius(temp)
>>>   print "%d Fahrenheit = %d Celsius" % (temp, convertedTemp)
>>>
>>> def convertToFahrenheit(t):
>>>   tF = (9.0/5.0) * (t + 32)
>>>   return tF
>>>
>>> def convertToCelsius(t):
>>>   tC = (9.0/5.0) * (t - 32)
>>>   return tC
>>>
>>>         convertedTemp = convertToFahrenheit(temp)
>>> NameError: name 'convertToFahrenheit' is not defined
>>>
>>> This is most likely a very simple error, but can someone please clarify
>>> for
>>> me why it's behaving this way?
>>>
>>
>> Others have explained that you need to execute the function
>> definitions before Python sees the name. You can do this in
>> two ways depending on taste.
>> 1) As suggested move your main code below the function definitions.
>> 2) move your main code into a function - traditionally called main()
>>   then call main as the last line of your code.
>>
>> The second method has two advantages:
>> 1) It maintains the top-down design style if thats your preferred style
>> 2) It makes it much easier to make the file into a reusable module.
>>
>> It has two minor disadvantages:
>>
>> 1) The extra function call (main() ) slows things down by a tiny amount
>> 2) the extra indentation level of being inside a function reduces the page
>>   width slightly
>>
>> HTH,
>>
>> --
>> Alan Gauld
>> Author of the Learn to Program web site
>> http://www.freenetpages.co.uk/hp/alan.gauld
>>
>> _______________________________________________
>> Tutor maillist  -  Tutor at python.org
>> http://mail.python.org/mailman/listinfo/tutor
>>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.python.org/pipermail/tutor/attachments/20080815/b51e26ac/attachment.htm>


More information about the Tutor mailing list