-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathchapter7.html
More file actions
227 lines (202 loc) · 8.04 KB
/
chapter7.html
File metadata and controls
227 lines (202 loc) · 8.04 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<meta name="description"
content="Chapter 7 of Python Zero to Hero: learn how to define and call functions, use args/kwargs, docstrings, and structure modules & packages."/>
<meta name="keywords"
content="Python, functions, def, arguments, return, docstring, scope, *args, **kwargs, modules, packages, import"/>
<meta name="author" content="Luca Bocaletto"/>
<title>Chapter 7 – Functions & Modules | Python Zero to Hero</title>
<!-- Bootstrap 5 CSS -->
<link
href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/css/bootstrap.min.css"
rel="stylesheet"
integrity="sha384-YSa3P1QY0VSei3nHevwltF1Jxv2pT3z5z0R6x35o1XQdYzdgQc8sYC+bS9v+g3Tc"
crossorigin="anonymous"
/>
<!-- Highlight.js CSS -->
<link
rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.8.0/styles/github.min.css"
integrity="sha512-94jnYVzi0AuOmT1JrLJiqxGWM1ZwVz4i1oF6XD2fXZj2lq+OJ9GSeUWLeFN5svoe0WyWkDi/gAhFI8QeYQj1Rg=="
crossorigin="anonymous"
referrerpolicy="no-referrer"
/>
<style>
body { padding-top: 4.5rem; }
pre code { font-size: .9rem; }
.btn-py { font-family: monospace; }
</style>
</head>
<body>
<!-- Navbar -->
<nav class="navbar navbar-expand-lg navbar-dark bg-dark fixed-top">
<div class="container">
<a class="navbar-brand" href="index.html">Python Zero to Hero</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse"
data-bs-target="#navContent" aria-controls="navContent"
aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navContent">
<ul class="navbar-nav ms-auto">
<li class="nav-item"><a class="nav-link" href="chapter6.html">Chapter 6</a></li>
<li class="nav-item"><a class="nav-link" href="index.html">Index</a></li>
<li class="nav-item"><a class="nav-link" href="chapter8.html">Chapter 8</a></li>
<li class="nav-item">
<a class="nav-link" href="https://github.com/bocaletto-luca/python-zero-to-hero" target="_blank">
GitHub Repo
</a>
</li>
</ul>
</div>
</div>
</nav>
<!-- Main Content -->
<main class="container">
<!-- Header -->
<header class="my-4">
<h1 class="display-6">Chapter 7: Functions & Modules</h1>
<p class="text-muted">
Define reusable functions, document them with docstrings, handle flexible arguments, and organize code into modules & packages.
</p>
<a href="src/chapter7.py" download class="btn btn-outline-primary btn-sm btn-py">
Download <code>chapter7.py</code>
</a>
<hr>
</header>
<!-- Objectives -->
<section id="objectives" class="mb-5">
<h2>Objectives</h2>
<ul>
<li>Define and call functions with positional, keyword and default arguments.</li>
<li>Write clear docstrings and inspect them via <code>help()</code>.</li>
<li>Understand local vs global scope; use <code>global</code> if needed.</li>
<li>Use <code>*args</code> and <code>**kwargs</code> for variable arguments.</li>
<li>Create and import modules and packages; understand <code>__name__ == "__main__"</code>.</li>
</ul>
</section>
<!-- 1. Defining Functions -->
<section id="defining" class="mb-5">
<h2>1. Defining Functions</h2>
<p>Use <code>def</code> keyword. Specify parameters and <code>return</code> a value:</p>
<pre><code class="python">def greet(name):
"""Return a greeting string for the given name."""
return f"Hello, {name}!"
msg = greet("Alice")
print(msg) # Hello, Alice!</code></pre>
<p>Parameters can have default values:</p>
<pre><code class="python">def power(base, exp=2):
return base ** exp
print(power(5)) # 25
print(power(2, 3)) # 8</code></pre>
</section>
<!-- 2. Docstrings & Scope -->
<section id="docstrings" class="mb-5">
<h2>2. Docstrings & Scope</h2>
<p>Document functions with a triple-quoted string immediately below <code>def</code>:</p>
<pre><code class="python">def add(a, b):
"""
Add two numbers.
Args:
a (int): first addend
b (int): second addend
Returns:
int: sum of a and b
"""
return a + b
help(add)</code></pre>
<p>Variables inside functions are local by default:</p>
<pre><code class="python">x = 10
def foo():
x = 5 # local x
return x
print(foo(), x) # 5 10</code></pre>
<p>Use <code>global</code> to modify a module-level variable:</p>
<pre><code class="python">counter = 0
def inc():
global counter
counter += 1</code></pre>
</section>
<!-- 3. *args & **kwargs -->
<section id="varargs" class="mb-5">
<h2>3. *args & **kwargs</h2>
<p>Accept arbitrary positional args:</p>
<pre><code class="python">def summarize(*args):
return sum(args)
print(summarize(1,2,3,4)) # 10</code></pre>
<p>Accept arbitrary keyword args:</p>
<pre><code class="python">def config(**kwargs):
for key, val in kwargs.items():
print(f"{key} = {val}")
config(host="localhost", port=8080)</code></pre>
<p>Combine both:</p>
<pre><code class="python">def mixed(a, *args, **kwargs):
print(a, args, kwargs)
mixed(1,2,3, x=10, y=20)</code></pre>
</section>
<!-- 4. Modules & Packages -->
<section id="modules" class="mb-5">
<h2>4. Modules & Packages</h2>
<p>Every <code>.py</code> file is a module. Import with:</p>
<pre><code class="python"># file: math_utils.py
def square(x):
return x*x
# in another file
import math_utils
print(math_utils.square(5))</code></pre>
<p>Use <code>from … import …</code> to bring names into scope:</p>
<pre><code class="python">from math_utils import square
print(square(6))</code></pre>
<p>Group modules in a directory with an <code>__init__.py</code> to form a package:</p>
<pre><code class="bash">project/
└── utils/
├── __init__.py
└── math_utils.py</code></pre>
<p>Protect script entry point:</p>
<pre><code class="python">if __name__ == "__main__":
# code to run when executed directly
pass</code></pre>
</section>
<!-- Exercises -->
<section id="exercises" class="mb-5">
<h2>Exercises</h2>
<ol>
<li>Write a function <code>multiply(a, b=1)</code> and test it with different args.</li>
<li>Create <code>stats.py</code> module with <code>mean()</code> and <code>median()</code>, then import and use them.</li>
<li>Implement a function accepting any number of positional and keyword args, and print them.</li>
<li>Build a package <code>mypkg</code> with two modules and demonstrate importing from it.</li>
</ol>
</section>
<!-- Navigation -->
<nav class="d-flex justify-content-between mb-5">
<a href="chapter6.html" class="btn btn-outline-secondary">← Chapter 6</a>
<a href="chapter8.html" class="btn btn-primary">Chapter 8 →</a>
</nav>
</main>
<!-- Footer -->
<footer class="text-center py-4 border-top">
<small>
© 2025 Python Zero to Hero •
<a href="https://github.com/bocaletto-luca/python-zero-to-hero" target="_blank">
bocaletto-luca/python-zero-to-hero
</a>
</small>
</footer>
<!-- Bootstrap & Highlight.js -->
<script
src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/js/bootstrap.bundle.min.js"
integrity="sha384-pQjTSprQoSWb8PQmxHkFvHUuI+13Z2VBxXc5xykxDc8/8aMbkwg/Sf5FCvbyT1Kg"
crossorigin="anonymous"
></script>
<script
src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.8.0/highlight.min.js"
integrity="sha512-v+HDTvKi4ym72wvsLmDdWKH1Z9r7qmOZEk11Kd/PO5vQRO3KHSEt+XeajpxdsBUW5Fve4BJR+wHrHBW2ApwBMQ=="
crossorigin="anonymous"
referrerpolicy="no-referrer"
></script>
<script>hljs.highlightAll();</script>
</body>
</html>