0% found this document useful (0 votes)
38 views46 pages

ModulesAndScripts

This document discusses modules, scripts, and input/output in Python. It covers running Python code from files called modules or scripts instead of interactively. The print and input statements are introduced for displaying and getting values. Formatting output and adding comments to improve readability of scripts is also covered.

Uploaded by

gregor alexander
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
38 views46 pages

ModulesAndScripts

This document discusses modules, scripts, and input/output in Python. It covers running Python code from files called modules or scripts instead of interactively. The print and input statements are introduced for displaying and getting values. Formatting output and adding comments to improve readability of scripts is also covered.

Uploaded by

gregor alexander
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 46

2.

Modules, Scripts, and I/O

Topics:
Script Mode
Modules
The print and input statements
Formatting
First look at importing stuff from
other modules
The Windchill Calculation
Let’s compute the windchill temperature given
that the air temperature is T = 32F and the wind
is W = 20mph.

Here is the formula courtesy of the National


Weather Service:

Wchill  (35.74  0.6215  T )  (35.75  0.4275  T ) W .16

The formula only applies if T <= 50F and W>=3mph.


Use Python in Interactive Mode
>>> Temp = 32
>>> Wind = 20
>>> A = 35.74
>>> B = .6215
>>> C = -35.75
>>> D = .4275
>>> e = .16
>>> WC = (A+B*Temp)+(C+D*Temp)*Wind**e
>>> print WC
19.9855841878

The print statement is used for displaying values in variables.


Quick Note on print

The line

>>> print WC

results in the display of the value currently


housed in the variable WC

More on the print statement later.


Motivating “Script Mode”

What is the new windchill if the wind is


increased from 20mph to 30mph?

Looks like we have to type in the same


sequence of statements. Tedious.

Wouldn’t it be nice if we could store the


sequence of statements in a file and then have
Python “run the file” after we changed
Wind = 20 to Wind = 30 ?
Script Mode

Instead of running Python in interactive mode,


we run Python in script mode.

The code to be run (called a script) is entered


into a file (called a module).

We then ask Python to “run the script”.


What is a Module?

A module is a .py file that contains Python code.

In CS 1110, these are created using Komodo Edit.


The Module WindChill.py
WindChill.py

Temp = 32
Wind = 20
A = 35.74
B = .6215
C = -35.74
D = .4275
e = .16
WC = (A+B*Temp)+(C+D*Temp)*Wind**e
print WC

Produced using Komodo Edit. This is our first draft.


Running the Module
Here are the steps to follow in the
command shell:

1. Navigate the file system so that you are


“in” the same diretory that houses
WindChill.py

2. Type: python WindChill.py


Details

Suppose I have a directory on my desktop


called TODAY where I keep all my python files
for today’s lecture.
I navigate the file system until I get this
prompt:

C:\Users\cv\Desktop\TODAY>
Asking Python to Run
the Code in WindChill.py

C:\Users\cv\Desktop\TODAY> Python WindChill.py

19.6975841877955

To save space in subsequent slides, we will refer to


C:\Users\cv\Desktop\TODAY> as Blah\Blah>
Multiple Statements on a Line
Can put multiple statements on a line. Separate
the statements with semicolons.

WindChill.py
Temp = 32
Wind = 20
A=35.74;B=.6215;C=-35.74;D=.4275;e=.16
WC = (A+B*Temp)+(C+D*Temp)*Wind**e
print WC

For lecture slides we will sometimes do this to save space.


But in general, it makes for ``dense reading’’ and should be avoided.
Module Readability: Comments
Comments begin with a “#”

WindChill.py

Temp = 32
Wind = 20
# Model Parameters
A=35.74;B=.6215;C=-35.74;D=.4275;e=.16
# Compute and display the windchill
WC = (A+B*Temp)+(C+D*Temp)*Wind**e
print WC
Comments: Guidelines
Comments can also appear on the same line
as a statement:

Wind = 20 # wind speed in miles-per-hour

Everything to the right of the “#” is


part of the comment and not part of the
program.
Comments and Readability

Start each program (script) with a concise


description of what it does.

Define each important variable/constant.

A chunk of code with a specific task should


be generally be prefaced with a concise
comment.
Module Readability: docstrings
A special comment at the top of the module.

WindChill.py

“““Computes windchill as a function of


wind(mph)and temp (Fahrenheit).”””
Temp = 32
Wind = 20
# Model Parameters
A=35.74;B=.6215;C=-35.74;D=.4275;e=.16
# Compute and display the windchill
WC = (A+B*Temp)+(C+D*Temp)*Wind**e
print WC
Docstrings: Guidelines
Docstrings are multiline comments that are
delimited by triple quotes: “““

They are strategically located at the beginning


of “important” code sections.

Their goal is to succinctly describe what the


code section is about.

One example of an “important” code section is a module.


Trying Different Inputs
WindChill.py

“““Computes windchill as a function of


wind(mph)and temp (Fahrenheit).”””
Temp = 32 Can we be more
Wind = 20 flexible here?

# Model Parameters
A=35.74;B=.6215;C=-35.74;D=.4275;e=.16
# Compute and display the windchill
WC = (A+B*Temp)+(C+D*Temp)*Wind**e
print WC
Handy Input

If we want to explore windchill as a


function of windspeed and temperature,
then it is awkward to proceed by editing
the module WindChill.py every time
we want to check out a new wind/temp
combination.

The input statement addresses this issue.


The input Statement

The input statement is used to solicit


values via the keyboard:

input( < string that serves as a prompt > )

Later we will learn how to input data from a file.


Temp and Wind via input
WindChill.py
“““Computes windchill as a function of
wind(mph)and temp (Fahrenheit).”””

Temp = input(‘Enter temp (Fahrenheit):’)


Wind = input(‘Enter wind speed (mph):’)

# Model Parameters
A=35.74;B=.6215;C=-35.74;D=.4275;e=.16
# Compute and display the windchill
WC = (A+B*Temp)+(C+D*Temp)*Wind**e
print WC
A Sample Run
The prompt is displayed…

> Enter temp (Fahrenheit) :

And you respond…

> Enter temp (Fahrenheit) : 15


A Sample Run
The next prompt is displayed…

> Enter wind speed (mph) :

And you respond again…

> Enter wind speed (mph) : 50


A Sample Overall “Dialog”

BlahBlah> python WindChill.py


Enter temp (Fahrenheit) : 15
Enter wind speed (mph) : 50
-9.79781580448
For more on Keyboard Input

Practice with the demo file


ShowInput.py

There is an alternative to input called


raw_input

It is handier in certain situations. Practice with

ShowRawInput.py
More Readable Output

The print statement can be used to format


output in a way that facilitates the
communication of results.

We don’t need to show wind chill to the


12th decimal!
More Readable Output
WindChill.py
“““Computes windchill as a function of
wind(mph)and temp (Fahrenheit).”””

Temp = input(‘Enter temp (Fahrenheit):’)


Wind = input(‘Enter wind speed (mph):’)

# Model Parameters
A=35.74;B=.6215;C=-35.74;D=.4275;e=.16
# Compute and display the windchill
WC = (A+B*Temp)+(C+D*Temp)*Wind**e
print ' Windchill :%4.0f' % WC
The “Dialog” With Formatting
BlahBlah> WindChill
Enter temp (Fahrenheit) : 15 print
Enter wind speed (mph) : 50 without
formatting
-9.79781580448

BlahBlah> WindChill
Enter temp (Fahrenheit) : 15 print
Enter wind speed (mph) : 50 with
formatting
Windchill : -10
The print Statement

The print statement tries to intelligently


format the results that it is asked to
display.

print with formatting puts you in control.

Later we will learn how to direct output to a file


print w/o Formatting
Script: x = 2./5.
print x
x = 1./3.
print x
x = 1234.5678901234
print x

Output: 0.4
0.333333333333
1234.56789012
For float values, print (by itself) displays up to 12 significant digits
print w/o Formatting

Script: x = 1234
y = 12345678
print x,y

Output:
1234 12345678

To display more then one value on a line, separate the references with commas.
A single blank is placed in between the displayed values.
print with the %f Format

x = 1234.123456789
print ‘x = %16.3f’ %x
print ‘x = %16.6f’ %x
print ‘x = %16.9f’ %x

x = 1234.123
x = 1234.123457
x = 1234.123456789

Formatted print statements are developed by “trial and error.”


It not a topic for memorization and it does not show up on exams.
print with the %e Format

x = 1234.123456789
print ‘x = %16.3e’ %x
print ‘x = %16.6e’ %x
print ‘x = %16.9e’ %x

x = 1.234e+03
x = 1.234123e+03
x = 1.234123456e+03

Formatted print statements are developed by “trial and error.”


It not a topic for memorization and it does not show up on exams.
print with the %d Format

x = 1234
print ‘x = %4d’ %x
print ‘x = %7d’ %x
print ‘x = %10d’ %x

x = 1234
x = 1234
x = 1234
Formatted print statements are developed by “trial and error.”
It not a topic for memorization and it does not show up on exams.
print with the %s Format

Script: Band = ‘The Beatles’


print ‘%s in 1964’ % Band

Output: The Beatles in 1964

Strings can be printed too


Formatted Print With More than
1 Source Value
Script:

y1 = 1964
Need parentheses
y2 = 1971 here.
Band = ‘The Beatles’
print ‘%s in %4d and %4d’ % (Band,y1,y2)

Output:

The Beatles in 1964 and 1971


print with Formatting
print < string with formats > %( < list-of-variables > )
A string that Comma-separated,
includes e.g., x,y,z. One
things like variable for each
%10.3f. %3d, format marker
%8.2e, etc in the string. The
Parentheses are
Required if more
than one variable.

Practice with the demo file ShowFormat.py


Why Program Readability and
Style is Important

How we “do business” in commerical, scientific,


and engineering settings increasingly relies on
software.

Lack of attention to style and substandard


documentation promotes error and makes it
hard to build on one another’s software.
Another Detail
All modules that are submitted for grading
should begin with three comments.

WindChill.py
# WindChill.py Name of module

# Xavier Zanzibar (xz3) Your name and netid


# January 1, 1903 Date

etc
A Final Example

Write a script that solicits the area of


a circle and prints out the radius.
Preliminary Solution

Radius.py

A = input(‘Enter the circle area: ‘)


r = sqrt(A/3.14)
print r

The Math: solve A = pi*r*r for r.


We Get an Error

A = input(‘Enter the circle area: ‘)


r = sqrt(A/3.14)
print ‘The radius is %6.3f’ % r

r = sqrt(A/3.14)
NameError: name 'sqrt' is not defined

sqrt is NOT a built-in function


Final Solution
Radius.py

from math import sqrt


A = input(‘Enter the circle area: ‘)
r = sqrt(A/3.14)
print ‘The radius is %6.3f’ % r

We are importing the function sqrt


from the math module.

The Math: solve A = pi*r*r for r.


The Idea Behind import
People write useful code and place it in
modules that can be accessed by others.

The import statement makes this possible.

One thing in the math module is the square


root function sqrt.

If you want to use it in your module just say

from math import sqrt


Better Final Solution
Radius.py

from math import sqrt,pi


A = input(‘Enter the circle area: ‘)
r = sqrt(A/pi)
print ‘The radius is %6.3f’ % r

We are importing the function sqrt and


the constant pi from the math module.

Can import more than one thing from a module. Much more on import later.
Sample Run

C:\Users\cv\Desktop\TODAY> Python Radius.py


Enter the circle area: 10
The radius is 1.785

For more insights, check out the lecture script SurfaceArea.py.

You might also like