MicroPython background knowledge
Since MaixPy is developed and built on top of MicroPython,
The final interface provided to users is Micropython, so we need to be familiar with the basic knowledge and syntax of
MicroPython at the beginning of development using MaixPy
MicroPython is a streamlined and efficient implementation of the programming language Python3. The syntax is consistent with Python3, but only a small part of the Python standard library is implemented. It is optimized and can be used in resource-constrained environments such as MCU and WIFI SOC. So we To use MicroPython, you need to understand its syntax.
If you have previous programming experience in C/C++/Java (or any other language), it is recommended (Liao Xuefeng's Python Tutorial).
If you do not have any programming experience before, recommend (Learn Python in a Stupid Way).
REPL and serial port
First, disconnect the connection between the development board and MaixPy IDE, otherwise the serial port will conflict!
Open a terminal window in MaixPy IDE
print('The quick brown fox','jumps over','the lazy dog')
The quick brown fox jumps over the lazy dog
print() will print each string in turn, and will output a space when it encounters a comma ",". Therefore, the output string is spelled like this:
The quick brown fox jumps over the lazy dog
print() can also print integers or calculate results:
print(300) 300 print(100 + 200) 300
Therefore, we can print the result of calculating 100 + 200 more beautifully:
print('100 + 200 =', 100 + 200) 100 + 200 = 300
Note that for 100 + 200, the Python interpreter automatically calculates the result 300, but '100 + 200 ='is a string instead of a mathematical formula, and Python treats it as a string.
MicroPython basic syntax
In Python, the equal sign
= is an assignment statement, which can assign any data type to a variable. The same variable can be assigned repeatedly, and it can be a variable of different types, for example:
a = 123 # a is an integer print(a) a ='ABC' # a becomes a string print(a)
This kind of language with variable types is called dynamic language, and its counterpart is static language. A static language must specify the variable type when defining a variable. If the type does not match when assigning a value, an error will be reported. For example, Java is a static language, and the assignment statement is as follows (// means comment):
int a = 123; // a is an integer variable a = "ABC";// Error: Cannot assign a string to an integer variable
Compared with static languages, dynamic languages are more flexible for this reason.
One of the built-in data types of Python is list: list.
list is an ordered collection, elements can be added and deleted at any time. For example, to list the names of all classmates in the class, you can use a list to indicate:
classmates = ['Michael','Bob','Tracy'] classmates ['Michael','Bob','Tracy']
The variable classmates is a
len() function to get the number of list elements:
Use the index to access the elements at each position in the list, the index starts from 0:
classmates 'Michael' classmates 'Bob' classmates 'Tracy' classmates Traceback (most recent call last): File "<stdin>", line 1, in <module> IndexError: list index out of range
When the index exceeds the range, Python will report an IndexError error, so make sure that the index does not exceed the range, remember that the index of the last element is len(classmates)-1.
If you want to get the last element, in addition to calculating the index position, you can also use -1 as an index to get the last element directly:
By analogy, you can get the second to last and third to last:
classmates[-2] 'Bob' classmates[-3] 'Michael' classmates[-4] Traceback (most recent call last): File "<stdin>", line 1, in <module> IndexError: list index out of range
Of course, the fourth from last crossed the line.
The list is a variable ordered list, so you can append elements to the list to the end:
classmates.append('Adam') classmates ['Michael','Bob','Tracy','Adam']
You can also insert the element into a specified position, such as the position with index number 1:
classmates.insert(1,'Jack') classmates ['Michael','Jack','Bob','Tracy','Adam']
To delete the element at the end of the list, use the pop() method:
classmates.pop() 'Adam' classmates ['Michael','Jack','Bob','Tracy']
To replace an element with another element, you can directly assign it to the corresponding index position:
classmates ='Sarah' classmates ['Michael','Sarah','Tracy']
The data types of the elements in the list can also be different, for example:
L = ['Apple', 123, True]
If there is no element in a list, it is an empty list with a length of 0:
L =  len(L) 0
Another kind of ordered list is called tuple: tuple.
Tuple is very similar to list, but once the
tuple is initialized, it cannot be modified. For example, it also lists the names of classmates:
classmates = ('Michael','Bob','Tracy')
Now, the tuple of classmates cannot be changed, and it does not have methods such as append(), insert(). The other methods of obtaining elements are the same as list, you can use classmates, classmates[ normally -1), but cannot be assigned to another element.
What is the point of an immutable tuple? Because tuples are immutable, the code is safer. If possible, try to use tuple instead of list.
The trap of tuple: When you define a tuple, the elements of the tuple must be determined at the time of definition, such as:
t = (1, 2) t (1, 2)
However, to define a A tuple with only 1 element, if you define it like this:
t = (1) t 1
But at this time, the definition is not tuple, t is an integer variable, and the value of variable t is 1!
This is because parentheses () can represent tuples and parentheses in mathematical formulas, which creates ambiguity.Therefore, Python stipulates that in this case, the calculation is based on parentheses, and the calculation result is naturally 1.
Therefore, the definition of tuple with only 1 element must add a comma
,, to disambiguate:
t = (1,) t (1,)
When Python displays a tuple with only 1 element, it will also add a comma
, to prevent you from misunderstanding it as a bracket in the sense of mathematical calculations.
The complete form of the if statement is:
if <condition judgment 1>: <Execute 1> elif <condition judgment 2>: <Execute 2> elif <condition judgment 3>: <Execute 3> else: <Execute 4>
age = 20 if age >= 6: print('teenager') elif age >= 18: print('adult') else: print('kid')
There are two types of Python loops, one is the
for...in loop, which iterates over each element in a list or tuple in turn, see an example:
names = ['Michael','Bob','Tracy'] for name in names: print(name)
Executing this code will print each element of names in turn:
Michael Bob Tracy
for x in ... loop is to substitute each element into the variable x, and then execute the statement of the indented block.
If you want to calculate the sum of integers from 1 to 100, it is a bit difficult to write from 1 to 100. Fortunately, Python provides a range() function that can generate a sequence of integers, which can be converted to a list by the list() function.
For example, the sequence generated by range(5) is an integer less than 5 starting from 0:
list(range(5)) [0, 1, 2, 3, 4]
range(101) can generate a sequence of 0-100 integers, calculated as follows:
sum = 0 for x in range(101): sum = sum + x print(sum)
The second type of loop is the while loop. For example, if we want to calculate the sum of all odd numbers within 100, we can use the while loop:
sum = 0 n = 99 while n> 0: sum = sum + n n = n-2 print(sum)
Data type conversion
Python's built-in common functions also include data type conversion functions, such as the int() function to convert other data types to integers:
>>> int('123') 123 >>> int(12.34) 12 >>> float('12.34') 12.34 >>> str(1.23) '1.23' >>> str(100) '100' >>> bool(1) True from machine import GPIO
In Python, to define a function, use the
def statement, write the function name, parentheses, the parameters in the parentheses and the colon
: in turn, and then write the function body in the indented block, and the return value of the function is returned The statement returns.
Let's write a function to calculate x2:
def power(x): return x * x
For the power(x) function, the parameter x is a positional parameter.
When we call the power function, we must pass in one and only one parameter x:
power(5) 25 power(15) 225
Now, what if we want to calculate x3? We can define another power3 function, but what if we want to calculate x4, x5...? We cannot define an infinite number of functions.
You may think of it, you can modify power(x) to power(x, n) to calculate xn, just do it:
def power(x, n): s = 1 while n> 0: n = n - 1 s = s * x return s
For this modified power(x, n) function, any n-th power can be calculated:
power(5, 2) 25 power(5, 3) 125
The modified power(x, n) function has two parameters: x and n. These two parameters are positional parameters. When the function is called, the two values passed in are assigned to the parameters x and n in order of position.
It is a very common operation to take some elements of a
tuple. For example, a list is as follows:
L = ['Michael','Sarah','Tracy','Bob','Jack']
Take the first 3 elements and complete the slice with one line of code:
L[0:3] means that it starts from index 0 and ends at index 3, but does not include index 3. That is, indexes 0, 1, 2, are exactly 3 elements.
If the first index is 0, it can also be omitted:
You can also start at index 1, and take out 2 elements:
tuple is also a kind of list, the only difference is that
tuple is immutable. Therefore,
tuple can also be sliced, but the result of the operation is still
(0, 1, 2, 3, 4, 5)[:3] (0, 1, 2)
String'xxx' can also be regarded as a kind of
list, each element is a character. Therefore, string can also be sliced, but the result of the operation is still a string:
Python is object-oriented programming, such as an LED light
from pyb import LED red_led = LED(1) red_led.on()
LED is a class, red_led is an object, you can operate this object, such as turning on, turning off, and viewing the value.
What is a module?
As the code increases, the code in a file will become longer and more difficult to understand.
In order to write maintainable code, we group many functions into different files. In Python, a
.py file is called a Module.
What are the benefits of modules?
Easy to reuse code! If I wrote a module and you also wrote a module, we have two modules. We organize these modules so that everyone can write a lot less code!
How to use modules?
import time time.sleep_ms(500)
import time is to import the
time module. The module can be imported through the
Please search for more MicroPython basic syntax tutorials.