Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d60a9f538d | ||
|
|
20fa53960d | ||
|
|
d58ebc1ebe | ||
|
|
09b4bc8f5b | ||
|
|
f2b35db671 |
1
.gitignore
vendored
@@ -1,2 +1,3 @@
|
||||
venv/
|
||||
site/
|
||||
videos/
|
||||
@@ -2,4 +2,10 @@
|
||||
|
||||
```bash
|
||||
ffmpeg -i in.mov -filter:v "setpts=0.5*PTS" out.gif
|
||||
ffmpeg -i in.mkv out.mov
|
||||
```
|
||||
|
||||
```bash
|
||||
git config --global pager.branch false
|
||||
git config --global pager.tag false
|
||||
```
|
||||
|
||||
28
converter.py
Normal file
@@ -0,0 +1,28 @@
|
||||
import subprocess
|
||||
import os
|
||||
import time
|
||||
|
||||
convert_dir = "/Users/ducoterra/Desktop/"
|
||||
debug = False
|
||||
|
||||
while True:
|
||||
# get a list of all .mov or .gif files
|
||||
movs = list(filter(lambda item: item.endswith(".mov"), os.listdir(convert_dir)))
|
||||
if debug:
|
||||
print(f"Found {len(movs)} .mov files.")
|
||||
gifs = list(filter(lambda item: item.endswith(".gif"), os.listdir(convert_dir)))
|
||||
if debug:
|
||||
print(f"Found {len(gifs)} .gif files.")
|
||||
|
||||
# find files that are not already gifs and aren't default
|
||||
not_done = list(filter(lambda mov: mov.replace(".mov",".gif") not in gifs and not mov.startswith("Screen Recording"), movs))
|
||||
if debug:
|
||||
print(f"Found {len(not_done)} to convert.")
|
||||
|
||||
for mov in not_done:
|
||||
print(f"converting {mov}. Ctrl + C to stop...")
|
||||
if debug:
|
||||
time.sleep(5)
|
||||
subprocess.run(['/usr/local/bin/ffmpeg', '-i', convert_dir + mov, '-filter:v', 'setpts=0.5*PTS', convert_dir + mov.replace(".mov",".gif")], capture_output=True)
|
||||
|
||||
time.sleep(1)
|
||||
242
docs/day2.md
Normal file
@@ -0,0 +1,242 @@
|
||||
# Day 2
|
||||
|
||||
## Back to the basics: and, or, not, if
|
||||
|
||||
Before we do anything more interesting we're going to have to cover our logical basics. In Python these are `not`, `and`, `or`, and `if`.
|
||||
|
||||
1. Stop your server with ++ctrl++ + C
|
||||
2. Type `python` in the terminal to open your python interpretor
|
||||
|
||||

|
||||
|
||||
|
||||
### not
|
||||
|
||||
1. Type `x = True` and press enter.
|
||||
2. Type `x` and press enter to see that x is true.
|
||||
3. Type `not x` and press enter. `not` inverts the value of `x`. So if `x` is True, `not x` is False.
|
||||
4. Type `not not x` and press enter. `not not x` inverts `not x`. You can chain `not` as many times as you want.
|
||||
5. Let's imagine we're building a weather app and we want to know if it's raining. Type `is_raining = True` and press enter.
|
||||
6. Type `print(f"should I wear a raincoat? {is_raining}")` and press enter.
|
||||
7. Today it's not raining. We could create a variable called `is_not_raining` but we could also just `not`. Type `print(f"should I wear a raincoat? {not is_raining}")`
|
||||
8. Type `not 'hello'` and press enter. This might seem strange but Python interprets a string as `True`. `not 'hello'` will return `False`.
|
||||
9. Type `not ''` and press enter. An empty string in Python is False. `not ''` returns `True`.
|
||||
|
||||
### and
|
||||
|
||||
1. In your terminal type `x = True` and press enter.
|
||||
2. Type `x` and press enter to see that x is True.
|
||||
3. Type `y = True` and press enter.
|
||||
4. Type `y` and press enter to see that y is True.
|
||||
5. Type `y and x` and press enter. `y` is true *and* `x` is true, so `y` and `x` is true.
|
||||
6. We're building our weather app to be more useful. We want to tell people if it's rainy and windy. Type `rainy = True` and press enter.
|
||||
7. Type `windy = True` and press enter.
|
||||
8. Type `rainy and windy` and press enter. We get True because it's rainy and windy.
|
||||
9. Today it's not windy. Type `rainy and not windy` and press enter. We get False because it isn't rainy *and* windy.
|
||||
10. Tomorrow it won't be windy and it also won't be rainy. Type `not rainy and not windy` and press enter. We get False because neither weather conditions are met.
|
||||
|
||||
### or
|
||||
|
||||
1. In your terminal type `x = True` and press enter.
|
||||
2. Type `x` and press enter to see that x is True.
|
||||
3. Type `y = False` and press enter.
|
||||
4. Type `y` and press enter to see that y is False.
|
||||
5. Type `y or x` and press enter. `x` is True so asking if x or y is true will result in `True`.
|
||||
6. Our weather app has millions of downloads. Our data suggests people don't like when it's cold or raining. Let's tell them when it's cold or raining.
|
||||
7. Type `cold = True` and press enter.
|
||||
8. Type `raining = True` and press enter.
|
||||
9. Type `cold or raining` and press enter. We get `True`, it is cold and it is raining.
|
||||
10. Today it isn't cold but it is raining. Type `not cold or raining`. We get `True`, it is still raining outside.
|
||||
11. Tomorrow it won't be cold and it won't be raining. Type `not cold or not raining`. We get `False` because neither of our disliked weather conditions are met.
|
||||
|
||||
### if
|
||||
|
||||
1. In your terminal type `x = True` and press enter.
|
||||
2. Type `x` and press enter to see that x is True.
|
||||
3. Type `y = False` and press enter.
|
||||
4. Type `y` and press enter to see that y is False.
|
||||
5. Type `if x:` and press enter. You'll see a `...`. Python is waiting for another input.
|
||||
6. Type ++tab++ `print('x is true!')` and press enter. You should see another `...`.
|
||||
7. Press enter again. 'x is true!' will print to the terminal.
|
||||
|
||||

|
||||
|
||||
8. Type `if y:` and press enter. Now type ++tab++ `print('y is true!')` and press enter twice. You won't see anything print.
|
||||
|
||||

|
||||
|
||||
9. Type `if not y:` and press enter. Now type ++tab++ `print('y is false!')` and press enter twice. You'll see 'y is false!') printed.
|
||||
10. Now that our weather app is sentient let's give it some decision making capability.
|
||||
11. Type `raining = True` and press enter.
|
||||
12. Type `if raining:` and press enter.
|
||||
13. Type ++tab++ `print('You should wear a rain jacket')` and press enter twice. Your weather app can now tell you to wear a jacket if it's raining outside.
|
||||
|
||||

|
||||
|
||||
14. Type `exit()` to exit
|
||||
|
||||
## Building a Terrible Weather App
|
||||
|
||||
1. Create a new file called `weather_app.py` by clicking the "add file" icon in the top left of VSCode.
|
||||
|
||||

|
||||
|
||||
2. We're going to create an app where the user has to guess the weather. We're going to need the python random module to generate random weather conditions.
|
||||
3. Add the following to the top of the page:
|
||||
|
||||
```python
|
||||
import random
|
||||
```
|
||||
|
||||

|
||||
|
||||
This tells python we intend to use the `random` package
|
||||
|
||||
4. We'll generate 4 weather conditions. Add the following after `import random`
|
||||
|
||||
```python
|
||||
warm = random.choice([True, False])
|
||||
cold = not warm
|
||||
raining = random.choice([True, False])
|
||||
snowing = not raining
|
||||
```
|
||||
|
||||

|
||||
|
||||
random.choice([True, False]) selects either True or False randomly.
|
||||
|
||||
5. Let's print our weather conditions in a cryptic way. Add the following below our variables:
|
||||
|
||||
```python
|
||||
if warm or cold:
|
||||
print("It's warm or cold.")
|
||||
|
||||
if raining or warm:
|
||||
print("It's raining or warm.")
|
||||
|
||||
if raining or snowing:
|
||||
print("It's raining or snowing.")
|
||||
|
||||
if cold or snowing:
|
||||
print("It's cold or snowing.")
|
||||
```
|
||||
|
||||

|
||||
|
||||
This will print weather conditions in pairs to make it more challenging for our users to guess the weather.
|
||||
|
||||
6. Now let's get our user input. Since we have 4 possible weather conditions we'll need 4 "guessing modules". Let's build the first one:
|
||||
|
||||
```python
|
||||
warm_guess = input("Is it warm? (y/n) ")
|
||||
if warm_guess == 'y' and warm:
|
||||
print('Correct!')
|
||||
elif warm_guess == 'n' and not warm:
|
||||
print('Correct!')
|
||||
else:
|
||||
print('Wrong!')
|
||||
```
|
||||
|
||||

|
||||
|
||||
We ask the user if it's warm. If they say 'y' and it is warm we tell them they got it right! If they guess wrong we tell them they are wrong.
|
||||
|
||||
7. We'll just repeat the guess module 3 more times for cold, raining, and snowing.
|
||||
|
||||
```python
|
||||
cold_guess = input("Is it cold? (y/n) ")
|
||||
if cold_guess == 'y' and cold:
|
||||
print('Correct!')
|
||||
elif cold_guess == 'n' and not cold:
|
||||
print('Correct!')
|
||||
else:
|
||||
print('Wrong!')
|
||||
|
||||
raining_guess = input("Is it raining? (y/n) ")
|
||||
if raining_guess == 'y' and raining:
|
||||
print('Correct!')
|
||||
elif raining_guess == 'n' and not raining:
|
||||
print('Correct!')
|
||||
else:
|
||||
print('Wrong!')
|
||||
|
||||
snowing_guess = input("Is it snowing? (y/n) ")
|
||||
if snowing_guess == 'y' and snowing:
|
||||
print('Correct!')
|
||||
elif snowing_guess == 'n' and not snowing:
|
||||
print('Correct!')
|
||||
else:
|
||||
print('Wrong!')
|
||||
```
|
||||
|
||||

|
||||
|
||||
8. Save with ++ctrl++ + S and run your weather app by typing `python weather_app.py`. Try to guess the weather.
|
||||
|
||||

|
||||
|
||||
## Pulling it all together with some Django
|
||||
|
||||
1. Let's make a weather app! Open "views.py" by clicking on it.
|
||||
|
||||

|
||||
|
||||
2. At the top of views.py add the following:
|
||||
|
||||
```python
|
||||
import random
|
||||
```
|
||||
|
||||

|
||||
|
||||
3. Now under all of our existing code in views.py add the following:
|
||||
|
||||
```python
|
||||
def weather(request):
|
||||
warm = random.choice([True, False])
|
||||
cold = not warm
|
||||
raining = random.choice([True, False])
|
||||
snowing = not raining
|
||||
|
||||
if warm:
|
||||
temperature_report = "It's warm out! Don't wear a jacket."
|
||||
else:
|
||||
temperature_report = "It's cold out! Wear a jacket."
|
||||
|
||||
if raining:
|
||||
precipitation_report = "It's raining! Bring an umbrella."
|
||||
else:
|
||||
precipitation_report = "It's snowing! Bring your skis."
|
||||
|
||||
return render(
|
||||
request,
|
||||
"mysite/index.html",
|
||||
{"data": temperature_report + " " + precipitation_report}
|
||||
)
|
||||
```
|
||||
|
||||

|
||||
|
||||
This creates a new "view" in our django app.
|
||||
|
||||
4. Open mysite/urls.py by clicking on it.
|
||||
|
||||

|
||||
|
||||
5. Under `path('', views.index),` add:
|
||||
|
||||
```python
|
||||
path('weather/', views.weather),
|
||||
```
|
||||
|
||||

|
||||
|
||||
6. Run your server with `python manage.py runserver` (if it isn't already running)
|
||||
|
||||

|
||||
|
||||
7. Navigate to <http://localhost:8000/weather>
|
||||
|
||||

|
||||
|
||||
Congratulations! You've added a new page to your app!
|
||||
BIN
docs/img/day2/add_weather.gif
Normal file
|
After Width: | Height: | Size: 367 KiB |
BIN
docs/img/day2/add_weather_path.gif
Normal file
|
After Width: | Height: | Size: 465 KiB |
BIN
docs/img/day2/conditions.png
Normal file
|
After Width: | Height: | Size: 162 KiB |
BIN
docs/img/day2/create_file.gif
Normal file
|
After Width: | Height: | Size: 123 KiB |
BIN
docs/img/day2/django_random.gif
Normal file
|
After Width: | Height: | Size: 359 KiB |
BIN
docs/img/day2/if_interpreter.gif
Normal file
|
After Width: | Height: | Size: 342 KiB |
BIN
docs/img/day2/if_prints.png
Normal file
|
After Width: | Height: | Size: 183 KiB |
BIN
docs/img/day2/import_random.png
Normal file
|
After Width: | Height: | Size: 155 KiB |
BIN
docs/img/day2/modules.png
Normal file
|
After Width: | Height: | Size: 254 KiB |
BIN
docs/img/day2/navigate_to_weather.gif
Normal file
|
After Width: | Height: | Size: 130 KiB |
BIN
docs/img/day2/open_urls.gif
Normal file
|
After Width: | Height: | Size: 204 KiB |
BIN
docs/img/day2/open_views.gif
Normal file
|
After Width: | Height: | Size: 260 KiB |
BIN
docs/img/day2/python_manage_run.gif
Normal file
|
After Width: | Height: | Size: 231 KiB |
BIN
docs/img/day2/rain_jacket.gif
Normal file
|
After Width: | Height: | Size: 407 KiB |
BIN
docs/img/day2/run_app.gif
Normal file
|
After Width: | Height: | Size: 386 KiB |
BIN
docs/img/day2/warm_module.png
Normal file
|
After Width: | Height: | Size: 209 KiB |
BIN
docs/img/day2/y_is_false.gif
Normal file
|
After Width: | Height: | Size: 412 KiB |
@@ -15,3 +15,10 @@
|
||||
|
||||
- The Interactive Python Prompt
|
||||
- A Python Program
|
||||
- A Django Project
|
||||
|
||||
### [Day 2](day2.md): not, and, or, if
|
||||
|
||||
- Back to the basics: and, or, not, if
|
||||
- Building a Terrible Weather App
|
||||
- Pulling it all together with some Django
|
||||
58
ffmpeg.yaml
Normal file
@@ -0,0 +1,58 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: ffmpeg
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
app: ffmpeg
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: ffmpeg
|
||||
spec:
|
||||
containers:
|
||||
- image: debian:latest
|
||||
name: ffmpeg
|
||||
command:
|
||||
- sleep
|
||||
- infinity
|
||||
volumeMounts:
|
||||
- mountPath: /in
|
||||
name: in
|
||||
- mountPath: /out
|
||||
name: out
|
||||
resources:
|
||||
limits:
|
||||
memory: "16Gi"
|
||||
cpu: "16"
|
||||
requests:
|
||||
memory: "1Mi"
|
||||
cpu: "1m"
|
||||
restartPolicy: Always
|
||||
volumes:
|
||||
- name: out
|
||||
persistentVolumeClaim:
|
||||
claimName: ffmpeg
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: ffmpeg-in
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteMany
|
||||
resources:
|
||||
requests:
|
||||
storage: 32Gi
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: ffmpeg-out
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteMany
|
||||
resources:
|
||||
requests:
|
||||
storage: 32Gi
|
||||
@@ -3,6 +3,7 @@ nav:
|
||||
- Home: index.md
|
||||
- Day 0: day0.md
|
||||
- Day 1: day1.md
|
||||
- Day 2: day2.md
|
||||
theme:
|
||||
name: material
|
||||
markdown_extensions:
|
||||
|
||||
16
my_program.py
Normal file
@@ -0,0 +1,16 @@
|
||||
def print_hello():
|
||||
print('hello, world!')
|
||||
|
||||
def print_goodbye():
|
||||
print('goodbye!')
|
||||
|
||||
def middle_stuff():
|
||||
x = 1
|
||||
y = 2
|
||||
print(x + y)
|
||||
my_name = "Reese"
|
||||
print(my_name)
|
||||
|
||||
print_hello()
|
||||
middle_stuff()
|
||||
print_goodbye()
|
||||
51
weather_app.py
Normal file
@@ -0,0 +1,51 @@
|
||||
import random
|
||||
|
||||
|
||||
warm = random.choice([True, False])
|
||||
cold = not warm
|
||||
raining = random.choice([True, False])
|
||||
snowing = not raining
|
||||
|
||||
if warm or cold:
|
||||
print("It's warm or snowing.")
|
||||
|
||||
if raining or warm:
|
||||
print("It's raining or warm.")
|
||||
|
||||
if raining or snowing:
|
||||
print("It's raining or cold.")
|
||||
|
||||
if cold or snowing:
|
||||
print("It's cold or snowing.")
|
||||
|
||||
warm_guess = input("Is it warm? (y/n) ")
|
||||
if warm_guess == 'y' and warm:
|
||||
print('Correct!')
|
||||
elif warm_guess == 'n' and not warm:
|
||||
print('Correct!')
|
||||
else:
|
||||
print('Wrong!')
|
||||
|
||||
cold_guess = input("Is it cold? (y/n) ")
|
||||
if cold_guess == 'y' and cold:
|
||||
print('Correct!')
|
||||
elif cold_guess == 'n' and not cold:
|
||||
print('Correct!')
|
||||
else:
|
||||
print('Wrong!')
|
||||
|
||||
raining_guess = input("Is it raining? (y/n) ")
|
||||
if raining_guess == 'y' and raining:
|
||||
print('Correct!')
|
||||
elif raining_guess == 'n' and not raining:
|
||||
print('Correct!')
|
||||
else:
|
||||
print('Wrong!')
|
||||
|
||||
snowing_guess = input("Is it snowing? (y/n) ")
|
||||
if snowing_guess == 'y' and snowing:
|
||||
print('Correct!')
|
||||
elif snowing_guess == 'n' and not snowing:
|
||||
print('Correct!')
|
||||
else:
|
||||
print('Wrong!')
|
||||