Python基础教程入门系列

github源代码下载

1. import

# -*- coding: utf-8 -*-
## 引入新的包
import turtle
import pickle  # 文件操作
import tensorflow as tf # alias tf
from time import time, localtime # 引入想要的功能
from time import *  # 引入所有功能
## 引入自定义包: 在Mac系统中,下载的python模块会被存储到外部路径site-packages,同样,我们自己建的模块也可以放到这个路径,最后不会影响到自建模块的调用。


""" If the module doesn't exist, pip install name_module # for python2 pip3 install name_module # for python3 pip install name_module=verson_num # for python install specific versions pip3 install name_module=version_num # for python3 specific versions pip install -U name_module # for update pip3 install -U name_module # for update """

2. 输入

a_input = input('please input a number:')
score = int(input('Please input your score: \n'))

3. 输出

print("hello, world")

## 占位符
## %d 整数
## %f 浮点数
## %s 字符串
## %x 十六进制整数
print('Age: %s. Gender: %s' % (25, True))

# format 占位符 {}
print('Hello, {0}, 成绩提升了 {1:.1f}%'.format('小明', 17.125))

4. 赋值,运算

### 特殊: 多变量赋值
a, b, c = 1, 2, 3
print(a, b, c)

## 加,减,乘,除,取余,取整, 乘方
## + , -, * , /, %, // , **
print(2**4)


## 编码
ord('中')  # 获取字符的整数表示
chr(12321)  # 获取编码对应的字符

'ABC'.encode('ascii')  # 编码为指定的bytes
'中文'.encode('utf-8')

b'\xe4\xb8\xad\xe6\x96\x87'.decode('utf-8')  # 读取字节流封装

len('ABC')  # 计算字节长度
len('\xe4\xb8\xad\xe6\x96\x87')

5. range使用: 工厂函数

range(1, 10)
stop = 10
range(stop=stop) ## it means range(0,10)
step = 2
range(1, stop=stop, step=step) # it means range from 1 to 10 step by 2

6. 条件语句

## python 用缩进表示代码块
age = input("input your age\n")
if int(age) > 18:
 print("already 成年")
elif int(age) > 30:
 print("30 more")
else:
 print('<18')
print('out of if else ')

# A exercise #

L = [
 ['Apple', 'Google', 'Microsoft'],
 ['Java', 'Python', 'Ruby', 'PHP'],
 ['Adam', 'Bart', 'Lisa']
]

print(L[0][0])
print(L[1][1])
print(L[2][2])

7.循环语句

for i in range(0, 7):
    print("hello world")

# while a<10 and b<20
t = turtle.Pen()
for i in range(0, 4):
    t.forward(100)
    t.left(90)

t = (1, 2)

## while 打印0-9 的数据
''' while True: print("always print True") '''
conditions = 0
while conditions < 10:
    print(conditions)
    conditions += 1

8. 比较操作

    比较运算符:
        小于(<)
        大于 (>)
        不大于 (<=)
        不小于 (>=)
        等于 (==)
        不等于 (!=)
            会return TrueFalse

9. 条件判断

# 条件 是 非None,非零, 则是True
# (list、 tuple 、dict 和 set )集合中,如果元素数量为0 ,则是False
age = 20
if age >= 18:
    print("your age is ", age)
    print('adult')
elif age >= 6:
    print('teenager')
else:
    print('kid')

worked = True
isDone = 'Done' if worked else 'not yet'
print(isDone)

10. 循环判断

for name in c:
    print(name)


print("range 函数生成整数序列 : ", range(4))

continue 和 break

11. 内置集合: list[], tuple()(用圆括号或者不用括号), dict{}, set([])

每个集合都能迭代

11.1 list 列表名 [ 索引地址值 ]

### name[ 1 :5] from 1 ~ 5

### name[ -1: -2 ] 倒数第二个开始,步长为2
### list 可变
c = [1, 2, 3, "张三"]
c.append("在末尾追加")
c.insert(1, "在位置1追加")
c.remove(2) # 移除 第一个值为2 的项
c.index(2)  # 显示第一个出现2 的索引
c[2:]  # 第二位以及之后的所有的项, 也可以理解为地址为2之后的地址为3以及之后的所有的值
c[-2:] # 列表倒数第二位以及,倒数第二位之后(从左向右)的所有项
c[0:3] # 第0位到第2位(第3位之前)所有项的值
#c.sort() # 默认从小到大, c.sort(reverse=True) # 从大到小排序
print(c[1])
print(c[2:4])
print(c[-1:: -2])
print(" list c 的长度 : %s " % len(c))

11.2多维列表

a = [1 ,2,3,4,5]     # 一行五列
multi_dim_a = [[1,2,3], [2,3,4], [3,4,5]]  # 三行三列

11.3tuple 元祖 不可变

classmates = ('Michael', 'Bob', 'Tracy')
classmates02 = 'Michael', 'Bob', 'Tracy'
t = ('a', 'b', ['A', 'B'])
t[2][0] = 'X'
t[2][1] = 'Y'
# t = ('a', 'b', ['X', 'Y'])

11.4 dict ,也就是字典

(其实也就是map),key - value 对应查询
### key 如果不存在就会报错 , get() 查询,不存在则为none
### 特点:
### 查找和插入的速度极快,不会随着key的增加而变慢;
### 需要占用大量的内存,内存浪费多。

## dict 是非有序的,需要顺序一致的dict, 使用collections模块中的OrderDict对象

d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}
print("字典: d.get('xx') = d['xx']: ", d.get('Bob'))
# 删除的两种方法
d.pop('Bob')
del d['Tracy']
d[1] = 20  # 添加的一种方法,直接添加

## 字典是无序容器,存储类型多变,
d4 = {'apple': [1,2,3], 'pear':{1:3, 3:'a'}, 'orange':func}
print(d4['pear'][3])    # a

11.5 set : 自带去重属性

## add , remove
s = set([1, 2, 3])
s.add(4)
print("s.add() ", s)
s.remove(4)
print("s.remove :: ", s)
print("s.pop() ", s.pop())
print("after s.pop()::", s)

12. 迭代器

13. 生成器

14. 定义一个函数

def hi_name(yourname):
    print(yourname)
def hi(yourname, num):
    print(yourname,num)

14.1 默认参数

## 函数声明只需要在需要默认参数的地方用 = 号给定即可, 但是要注意所有的默认参数都不能出现在非默认参数的前面
def function_name(price, color='red', brand='carmy', is_second_hand=True):
    print('price', price,
          'color', color,
          'brand', brand,
          'is_second_hand', is_second_hand, )
hi_name("这是自定义函数的定义输出")

14.2 自调用

'''
 如果执行该脚本的时候,该 if 判断语句将会是 True,那么内部的代码将会执行。
 如果外部调用该脚本,if 判断语句则为 False,内部代码将不会执行。 
'''
if __name__ == '__main__':
 #code_here
 print("测试使用的")

14.3 可变参数

def report(name, *grades):
    total_grade = 0
    for grade in grades:
        total_grade += grade
    print(name, 'total grade is ', total_grade)
report('wang', 12,14,16,20)

14.4 关键字参数

## universal_func(*args, **kw) ==> 可以代表任何函数
def portrait(name, **kw):
    print('name is', name)
    for k, v in kw.items():
        print(k, v)
print(portrait('Mike', age=24, country='China', education='bachelor'))

15. 全局变量

global_param = 100
def for_local():
    local_parm = 20
    print("value of local_parm is %d" % local_parm)
    print("value of global_parm is %d" % global_param)


# print("local_parm does not exit" % local_parm)
print("value of global_parm is %d" % global_param)

16. 文件操作

''' r 以只读方式打开文件,该文件必须存在。   r+ 以可读写方式打开文件,该文件必须存在。   rb+ 读写打开一个二进制文件,只允许读写数据。   rt+ 读写打开一个文本文件,允许读和写。   w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。   w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。   a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)   a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)   wb 只写打开或新建一个二进制文件;只允许写数据。   wb+ 读写打开或建立一个二进制文件,允许读和写。   wt+ 读写打开或着建立一个文本文件;允许读写。   at+ 读写打开一个文本文件,允许读或在文本末追加数据。   ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。 转义字符 输出 \' ' \" " \a ‘bi’响一声 \b 退格 \f  换页(在打印时) \n 回车,光标在下一行 \r 换行,光标在上一行 \t 八个空格(对齐) \\ \ '''
game_data = {"position": "N2 E3", "pocket": ["key", "knife"], "money": 160}
save_file = open("save.dat", "wb")  ## 其中形式有'w':write;'r':read.
pickle.dump(game_data, save_file)
save_file.close()  ## 关闭文件

load_file = open("save.dat", "rb")
load_game_data = pickle.load(load_file)
load_file.read()
load_file.readline()  # 读取第一行
load_file.readlines()  # python_list 形式
print(load_game_data)
load_file.close()

for x, y in [(1, 1), (2, 4), (3, 9)]:
    print(x, y)

16.1 for循环后面还可以加上if判断,这样我们就可以筛选出仅偶数的平方:

[x * x for x in range(1, 11) if x % 2 == 0]

[m + n for m in 'ABC' for n in 'XYZ']

import os  # 导入os模块,模块的概念后面讲到
[d for d in os.listdir('.')]  # os.listdir可以列出文件和目录

16.2 面对对象编程

class Calculator:       #首字母要大写,冒号不能缺
    name = 'Good Calculator'  #该行为class的属性
    price = 18
    def add(self,x,y):
        print(self.name)
        result = x + y
        print(result)
    def minus(self,x,y):
        result=x-y
        print(result)
    def times(self,x,y):
        print(x*y)
    def divide(self,x,y):
        print(x/y)

''' cal=Calculator() #注意这里运行class的时候要加"()",否则调用下面函数的时候会出现错误,导致无法调用. cal.name cal.add(10,20) '''


# __init__可以理解成初始化class的变量,取自英文中initial 最初的意思.可以在运行时,给初始值附值,
# 这里的下划线是双下划线
#
#
# 运行c=Calculator('bad calculator',18,17,16,15),然后调出每个初始值的值。看如下代码。

class Calculator:
    name = 'good calculator'
    price = 18
    def __init__(self,name,price,height,width,weight):   # 注意,这里的下划线是双下划线
        self.name=name
        self.price=price
        self.h=height
        self.wi=width
        self.we=weight

17. 异常处理

try:
    file=open('eeee.txt','r')  #会报错的代码
except Exception as e:  # 将报错存储在 e 中
    print(e)

18. ZIP函数

a=[1,2,3]
b=[4,5,6]
ab=zip(a,b)
print(list(ab)) ## 需要list 来可视化这个功能
for i,j in zip(a,b):
     print(i/2,j*2)

19. map

def fun(x,y):
    return (x+y)
list(map(fun,[1],[2]))
    原文作者:榴霖燚炀
    原文地址: https://blog.csdn.net/leojuner/article/details/81294805
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞