Python自学(适用于略有基础)

2024-06-09 03:04

本文主要是介绍Python自学(适用于略有基础),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Python语法(基于C语言基础和简单Python基础)

参考学习资料:【你觉得自己这辈子都学不会编程?超超超基础Python课程,3小时快速入门 【自学Python教程合集】【3小时快速入门Python】】 https://www.bilibili.com/video/BV1944y1x7SW/?share_source=copy_web&vd_source=3aa9ee0c4fcf2e52762a44f906c09534

命名规则

变量一般如下命名:

  • han_xiang
  • computer_science

类名一般如下命名:(驼峰命名法)

  • StudentCourse

数学运算

加减乘除

两个除号(//)表示除完后向下取整。

乘方:**

e.g. 2的三次方: 2 ∗ ∗ 3 2**3 23

其他复杂运算的数学公式:

import math

e.g.

import mathprint(math.log2(8))

可以通过查阅文档来寻找math库中提供的数学公式:

链接:https://docs.python.org/zh-cn/3/library/math.html

数据类型

  • 字符串 str
  • 整数 int
  • 浮点数 float
  • 布尔类型 bool
  • 空值类型 NoneType
  • 列表
  • 字典
  • ……
type("Hello") # <class 'str'>
type(6) # <class 'int'>
type(None) # <class 'NoneType'>

注意布尔类型的True和False首字母要大写。

输入语句

input("这里是给用户的一些提示")

条件语句

if [条件]:[动作]
elif [条件]:[动作]
else:[动作]

条件语句可以嵌套。

逻辑运算

  • 与:and
  • 或:or
  • 非:not

e.g.

not ( x > 5 and (x < 10 or x == 12))

列表

e.g.

shopping_list = ["键盘", "键帽"]
shopping_list.append("显示器") # 此时原先的列表已经改变
print(len(shopping_list)) # 打印列表里元素的数量
shopping_list.remove("显示器") # 该元素必须之前存在于列表中
shopping_list[1] = "音响" # 索引为1的元素被修改

Python的列表可以放不同类型的数据:

list1 = ["Hello"]
list1.append(66.6)
list1.append(True)
list1.append(None)
print(list1)

此外,Python还有很多可以针对列表的内置函数:

num_list = [1, 13, -7, 2, 96]
print(max(num_list))
print(min(num_list))
print(sorted(num_list))

字典&元组

→哈希表

e.g. 电话簿可以用人名查到手机号

contacts = {"小明": "13700000000","小花": "13700000001"}
print(contacts["小明"])

元组:(列表用方括号,元组用圆括号)

example_tuple = ("键盘", "键帽")

元组不可变,不能添加或删除元素。

字典与元组的结合使用:

contacts = {("张伟", 23): "15000000000",("张伟", 34): "15000000001",("张伟", 56): "15000000002"}zhangwei23_phone = contacts[("张伟", 23)]

字典和列表一样,是可变的。

如果想知道某个键是否已经存在,“键 in 字典”会返回一个布尔值,告知该键是否已经存在于字典里。

del contacts["小明"] # 删除这个键值对

for循环

迭代的对象可以是列表、字典、字符串等。

temperature_list = [36.4, 36.3, 37.2, 37.0]
for temp in temperature_list:# 对每个变量做一些事情# ……

对于字典,可以采用如下操作:

temperature_dict = {"111": 36.4, "112": 36.3, "113": 37.2, "114": 37.0}for staff_id, temperature in temperature_dict.items():if temperature >= 38:print(staff_id)

for循环结合range:

range的起始值在序列中,而结束值不在序列中。

for i in range(5, 10):print(i)

上述代码运行后,i会依次被赋值为5到9的数字并打印。

range()还可以包含第三个参数,表示步长,也就是每次跨几个数字。

格式化字符串

f-字符串:

gpa_dict = {"小明": 3.251, "小花": 3.869, "小李": 2.683, "小张": 3.685}
for name, gpa in gpa_dict.items():print(f"{name}你好,你的当前绩点为:{gpa:.2f}")

函数

e.g. 计算扇形面积

def calculate_sector(central_angle, radius):sector_area = central_angle / 360 * 3.14 * radius ** 2print(f"此扇形的面积为:{sector_area}")calculate_sector(160, 30)

函数也可以带return。

面向对象编程

e.g. 创建House类

class House:def __init__(self, 颜色, 位置, 卧室数):self.颜色 = 颜色self.位置 = 位置self.卧室数 = 卧室数house1 = House("紫色", "长沙", 4)
house2 = House("红色", "深圳", 3)

还可以在类中定义方法函数:

class Student:def __init__(self, name, student_id):self.name = nameself.student_id = student_idself.grades = {"语文": 0, "数学": 0, "英语": 0}def set_grade(self, course, grade): # 第一个“self”不能省略if course in self.grades:self.grades[course] = gradedef print_grades(self):print(f"学生{self.name} (学号:{self.student_id}) 的成绩为:")for course in self.grades:print(f"{course}: {self.grades[course]}分")

类的继承:

e.g. 人类和小猫都属于哺乳动物

class Mammal:def __init__(self, name, sex):self.name = nameself.sex = sexself.num_eyes = 2def breathe(self):print(self.name + "在呼吸...")def poop(self):print(self.name + "在拉屎...")class Human(Mammal): # 继承的父类要写在括号里def read(self):print(self.name + "在阅读...")class Cat(Mammal):def scratch_sofa(self):print(self.name + "在抓沙发...")

如果同时为Human和Cat添加has_tail属性,二者的取值结果并不相同。

解决:使用super()

class Mammal:def __init__(self, name, sex):self.name = nameself.sex = sexself.num_eyes = 2def breathe(self):print(self.name + "在呼吸...")def poop(self):print(self.name + "在拉屎...")class Human(Mammal):def __init__(self, name, sex):super().__init__(name, sex) # 这样会调用父类的构造函数self.has_tail = Falsedef read(self):print(self.name + "在阅读...")class Cat(Mammal):def __init__(self, name, sex):super().__init__(name, sex)self.has_tail = Truedef scratch_sofa(self):print(self.name + "在抓沙发...")

文件操作

相对路径&绝对路径

input()

异常处理

try:user_weight = float(input("请输入您的体重(单位:kg):"))user_weight = float(input("请输入您的身高(单位:m):"))user_BMI = user_weight / user_height ** 2
except ValueError: # 值错误print("输入非合法数字,请重新运行程序,并输入正确的数字。")
except ZeroDivisionError: # 分母为零错误print("身高不能为零,请重新运行程序,并输入正确的数字。")
except: # 其他错误print("发生了未知错误,请重新运行程序。")
else: # 当try语句没有产生任何错误时执行的语句print("您的BMI值为:" + str(user_BMI))
finally: # 无论错误发生与否,最终都会被执行的语句print("程序结束运行。")

代码测试

assert

assert 1 + 2 > 6 # AssertionError

Python单元测试库:unittest

e.g.

# my_calculator.py
# 实现代码
def my_adder(x, y):return x + y
# test_my_calculator.py
# 测试代码
import unittest
from my_calculator import my_adderclass TestMyAdder(unittest.TestCase):def test_positive_with_positive(self): # 函数名必须以“test_”开头self.assertEqual(my_adder(5, 3), 8)def test_negative_with_positive(self):...

写好测试用例后,在编辑器(e.g. PyCharm)的终端输入:

python -m unittest

测试通过打印“·”,测试不通过打印“F”。

unittest.TestCase类的常见测试方法:

  • assertEqual(A, B)
  • assertTrue(A)
  • assertIn(A, B)
  • assertNotEqual(A, B)
  • assertFalse(A)
  • assertNotIn(A, B)

高阶函数

一个函数的“函数名”作为参数传给另外一个函数,或一个函数的返回值为另外一个函数。

e.g.

def calculate_and_print(num, calculator):result = calculator(num)print(f"""| 数字参数 | {num} || 计算结果 | {result} |""")def calculate_square(num):return num * numdef calculate_cube(num):return num * num * numdef calculate_plus_10(num):return num + 10calculate_and_print(3, calculate_square) # 注意第二个参数传入的是函数名而非函数,不带括号

匿名函数

lambda num1, num2: num1 + num2 # 只能有一个语句/表达式

这篇关于Python自学(适用于略有基础)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1044067

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',