【Python】Python语言 3小时速通(有C语言基础版)

python从入门到实践

变量

message="hello world"

并不需要指出变量类型

方法

tittle()#以首字母大写的形式输出单词
upper()#全部大写输出
lower()#全部小写输出

存储数据时经常使用lower,因为无法确保数据是大写还是小写

rstrip()#输出删除字符串尾部多余的空格后的值
lstrip()#输出删除字符串头部多余的空格后的值
strip()#输出删除字符串两边多余的空格后的值

从这里可以看出python对于数据和字符处理具有很多优势

range(1,5,2)#从一到四找一个随机数,步长为2
value**2#value的平方

字符串拼接

message="hello world"
message2="python"
print(message.title()+" "+message2)

直接通过加号的形式拼接

打印换行符和制表符

"\t"#制表符
"\n"#换行符

他们都相当于字符(串)

强转

str(23)

不强转会报错

注释

用#而不是//

列表

增加元素

类似于数组,访问方式同数组

append()#在列表末尾添加一个元素
str.append('a')
insert()#在数组特定位置插入元素
str.insert(0,‘a')

按位置删除

del str[0]#删除第0个元素
str.pop(0)#删除某个位置的元素并返回,如果括号中不传参默认删除最后一个

按值删除

str.remove("0")#删除值为0的元素

排序

str.sort()#正序,sort不能直接在print中调用
str.sort(reverse=True)#反序
sorted(str)#临时输出排序后的数组,不改变原数组顺序

反序

str.reverse()#将数组倒序改变

数组长度

len(a)#返回值为a的长度
a[-1]#永远链接最后一个元素,除非a为空

列表推导式

数学运算

min(列表名),max(),sum()

列表格式操作

number=list(range(1,5))
print(number)
#list()转换为列表

列表解析

square=[value**2 for value in range(1,10,2)]
print(square)

切片

print(square[0:3])

截取0到3的部分

print(square[-3:])

只输出后三个元素

复制

new_square=square[:]#类似于克隆
new_square=square#类似于指针

元组

定义:不可变的列表,区别在于用元括号而非方括号

dimension=(1,100)

修改元组的唯一方式

dimension=(1,100)
print(dimension)

dimension=(100,100)
print(dimension)

重新定义元组

循环

for循环

magicians=['alice','bob','dad']
for magician in magicians:
    print(magician)

有C语言基础一秒看懂

while循环使用方法同上

while magician !="alice":

退出循环

break
continue

用法同C语言

if条件

if d==1:
    print(d)
if d==1 and d-1==0:
    print(d)
if d==1 or d-1==0:
    print(d)
if 1 in dimension:#检查列表里面有没有某个元素
    print(d)
if 1 not in dimension:#检查列表里面没有某个元素
    print(d)
if 1 not in dimension:#三重条件判断
    print(d)
elif 100 in dimension:
    print(dimension)
else:
    print(1)

有C语言基础一秒看懂

if birthday in pi:
	print("你的生日在圆周率里面")

py的这种方式让人感觉非常口语化

字典

字典的作用在于索引,形式上区别在于大括号

alien_0={'color':'green','point':'5'}
print(alien_0['color'])

字典的组成形式为一系列键值对,键值对之间用 , 隔开,键值对前为索引,后为值,通过 : 区分开.

键值对索引可以是任何形式的变量,值也是

alien_0['x_position']=100 #添加(修改)键值对
alien_0["y_position"]=10
print(alien_0)
del alien_0['x_position'] #删除键值对
print(alien_0)
alien_0={1:'green','point':'5'} #遍历键值对(两种方法输出结果不一样
for point in alien_0.items():
    print(point)

print(alien_0)
for key in alien_0.keys()://提取键
    print(key)
sorted(alien_0) #输出排序后的结果
set() #输出集合后的结果

字典嵌套

alien_0={'1':'green','point':'5'}
alien_1={'1':'green','point':'5'}
alien_2={'1':'green','point':'5'}

alien=[alien_0,alien_1,alien_2]
print(alien)
pizza={
    '1':"asd",
    '2':[1,2,3]
}
print(pizza)
print(pizza['2'])

输入

message=input("hello")
print(message)

结果是hello和输入的字符

input相当于兼顾了C语言中printf和scanf的功能

int('12') #将字符12强转为数字12

函数

def greet():
    print("hello")
greet()

先定义,后使用,高度依赖换行和缩进

传参

def greet(name):
    print("hello"+' '+name)
greet(input())

上面为函数传参的使用

两种传参方式:

def greet(name):
    print("hello"+' '+name)
greet('bob')

def greet(name):
    print("hello"+' '+name)
greet(name='bob')

默认值,输入具体值以后会冲掉默认值

def greet(name='bob'):
    print("hello"+' '+name)
greet()

默认值和传参至少有一个,也就是说必须函数里面每个变量都有值

返回值,有C语言基础一秒看懂,返回值类型任意

def greet(name='bob'):
    print("hello"+' '+name)
    return "yes"
print(greet())

传入多个参数

def greet(*name):
    print(name)
    return "yes"
print(greet('a','b'))

得到的name是一个元组

一个星号创建的是元组,两个星号创建的是字典,并且方式和建立有些不同

def greet(**name):
    print(name)
greet(asd='123')

导入包

导入函数

from g import greet

greet("alice")

导入文件

import g

g.greet("alice")

别名

import g as good

good.greet("alice")

类是面向对象编程的具体形式,类中具有属性和方法

类的基本声明:

class Dog:
    def __init__(self,name,age): #self是必须的,剩下两个表示属性
        self.name=name #对属性分别需要声明
        self.age=age 

类里面的函数被称为方法,上面的_init__就是类里面的初始化方法(受markdown语法限制这里写法可能不太正确

init的下划线是类里面的方法必须具备的,作为一个标志区别类里面的方法和类外面的函数

实例化对象and访问对象(类相当于一个模板,可以根据一个类创建多个对象)

my_dog=Dog('white',16)

print(my_dog.name)

默认属性

class Dog:
    def __init__(self,name):
        self.name=name
        self.age=12

my_dog=Dog('white')

print(my_dog.age)

默认属性不需要再init的参数里面体现,在实例化的时候也不需要写出来,但是可以直接调用获取这个值和修改

继承关系

class Dog:
    def __init__(self,name):
        self.name=name
        self.age=12

my_dog=Dog('white')
my_dog.age=16
print(my_dog.age)

class NBDog(Dog):
    def __init__(self,name):
        super().__init__(name)

上述代码先定义了Dog这个类,并且给定了初始化的方法,接下来重新定义了NBDog,NBDog是继承Dog类的子类,所以在声明变量之前首先需要class NBDog(Dog)表示新的类是继承之前类的,super()表示调用父类的方法(父类也被称为超类),所以调用父类的init的方法进行初始化。

定义子类的属性
class NBDog(Dog):
    def __init__(self,name):
        super().__init__(name)
        self.year=10 #新定义的子类的属性
my_NBdog=NBDog("black")
print(my_NBdog.year)
重写父类方法
class Dog:
    def __init__(self,name):
        self.name=name
        self.age=12
    def test(self):
        print(self.age)

my_dog=Dog('white')
my_dog.age=16
my_dog.test()

class NBDog(Dog):
    def __init__(self,name):
        super().__init__(name)
        self.year=10
    def test(self):
        print(f'my age is {self.age}') #这里要注意
my_NBdog=NBDog("black")
my_NBdog.test()

直接再写一个覆盖了就行

这段代码里面要注意最后一个print,这里输出以后{}中间的内容是年龄具体的变量值,f不会输出,他的作用是将大括号中的内容视为变量值,而不是都作为字符串输出

将类作为属性
class Ear:
    def __init__(self,length):
        self.length=length


class Dog:
    def __init__(self, name):
        self.name = name
        self.age = 12
        self.ear=Ear(100);
my_dog=Dog("black")
print(my_dog.ear.length)

如上,Ear是dog的一部分,结果是100

导入类包
from g import Car #导入方式

my_car=Car('tesla')
print(my_car.name)

from g import Car前后顺序不能互换

导入多个类时,在Car后面加逗号然后加入别的类

导入整个包,调用类时用点访问

import g

my_car=g.Car('tesla')
print(my_car.name)

文件操作和异常

读取文件操作

with open("test.txt") as hello: #打开文件,hello可以自定义变量名
    contents=hello.read() #读取文件中的内容到contents中
print(contents) #打印出contents中的内容

with的作用在于不需要手动关闭文件,表示在代码块中使用

在读取文件后显示的实际上末尾会多出来一个空行,因为文件读取到末尾会返回一个空字符串,而打印出来显示的就是空行

如果不想要这个空行的话可以使用print(contents.rstrip())来删除字符串末尾多余的空格或者换行

py在文件查询的过程中,默认是在与代码文件相同目录的文件夹进行查询,如果需要对子文件进行查询,需要找到其子文件夹

注意:在相对路径中,我们一般使用/这个斜杠,因为\这个反斜杠会被认为是转义字符的标志,如果非要用\这个斜杠的话,那就需要用两个\斜杠,表示对每两个\斜杠都转义为一个\斜杠

读取文件并逐行输出

filename="test.txt"
with open(filename) as hello:
    for line in hello:
        print(line)

读取文件内容并且存储到列表中

filename="test.txt"
with open(filename) as hello:
    lines=hello.readlines()
print(lines)

写入文件

filename="test.txt"
with open(filename,'w') as hello:
    hello.write("hello")

其中w表示写入模式,可以替换为r(读入模式),r+(读写模式),a(附加模式),如果忽略的话默认以只读模式打开

如果文件原本并不存在的话,open函数将会自动创建一个以其命名的文件

如果用w打开的话,文件内容会是新写入的内容,之前的内容会被清空

如果想要附加的话,要用a模式

异常

使用try和except组合来捕捉异常

try:
    print(5/0)
except:
    print("error")

实际上不同的异常,except后面应该接不同的异常,但是对于初学者可以直接都不用加,这样方便很多

如果不需要任何东西的话,在except后接pass就行

杂项

分析文本:

title="alice in bob"
print(title.split())

split方法表示根据空格分开文本,并且生成一个列表

json文件

写入json文件

import json

numbers=[1,3,5,9,4,11]
filename="numbers.json"

with open(filename,'w') as f:
    json.dump(numbers,f)

json.dump函数接受两个参数,第一个是传入的内容,第二个是文件名

读取json文件

import json

filename="numbers.json"

with open(filename) as f:
    numbers=json.load(f)
print(numbers)

使用json.load函数来读取或存储json文件中的数据

重构

将一整个函数分成多个子功能并且在需要时调用子功能

测试

import unittest #导入单元测试的包
from name_function import get_formatted_name #导入要测试的函数

class NamesTestCase(unittest.TestCase): #创建一个Test的类,要继承unittest.TestCase表示单元测试

    def test_first_last_name(self):
        formatted_name = get_formatted_name('janis', 'joplin') #后面是函数运行,前面用来接受返回的结果
        self.assertEqual(formatted_name, 'Janis Joplin') #断言方法相当于一个比较,比较前后是否相等
if __name__ == '__main__':
    unittest.main()

这个测试是单元测试,首先要导入单元测试的包,然后创建一个表示Test的类,接着定义一个方法,在方法中比较得到的结果与预期是否相符

最后的if是判断特殊变量是不是main,也就是说目前存放代码的文件,是不是你要执行运行的文件,如果是的话,name的值就是main,然后执行后面的测试

unnittest.main()函数每次都会先执行test_打头的函数,所以在定义测试函数的时候要注意函数的命名

常见的断言方法在这里插入图片描述

还有一个方法叫setup,在Test类中被优先调用。在测试自己编写的类时,方法setUp让测试方法编写起来更加容易:可以在setUp()方法中创建一系列实例并设置其属性,再在测试方法中直接使用这些实例。相比于在每个测试方法中都创建实例并设置属性,这种方法要更加容易。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/317057.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux系统中使用ln命令创建软连接

大家应该和我一样,第一次听到软连接这个词时感觉好高级啊,但其实也就那么回事,你完全可以将他类比为Windows系统中的快捷方式。 链接只是一个指向,并不是物理移动,类似Windows系统的快捷方式 1.功能和语法 功能&…

C#进阶学习

目录 简单数据结构类ArrayList声明增删查改遍历装箱拆箱 Stack声明增取查改遍历装箱拆箱 Queue声明增取查改遍历 Hashtable声明增删查改遍历装箱拆箱 泛型泛型分类泛型的作用泛型约束 常用泛型数据结构类List声明增删查改遍历 Dictionary声明增删查改遍历 LinkedList声明增删查…

Seata TM管理分支事务

TM相当于一个中间商,是没有涉及到任何数据库底层操作的。 TransactionalTemplate 1、TM向TC端发起一次开启全局事务的请求 io.seata.tm.api.TransactionalTemplate#beginTransaction --> io.seata.tm.api.DefaultGlobalTransaction#begin(int, java.lang.Strin…

APM链路监控: Linux 部署 pinpoint

目录 一、实验 1.环境 2. 准备 3.HBase单机部署 4.pinpoint部署 二、问题 1.pinpoint有哪些功能 2.pinpoint架构是如何组成的 3.Linux中自带的jdk 如何设置JAVA_HOME 4. hbase启动报错 5.hbase的master启动失败 6.JPS命令如何安装和使用 一、实验 1.环境 &#x…

Centos7.9服务器编译安装Nginx1.24.0和php8.3

Centos7.9服务器编译安装Nginx1.24.0和php8.3 服务器nginx原版本有安全漏洞,需要升级,由于原始是yum源安装,通过yum直接升级,无法正常升级完成,故而需要卸载yum源,重新编译安装。 1、查看原来nginx版本,ps查看原来nginx进程,运行状态: ps aux | grep nginx ​ root …

JAVAEE——request对象(三)

1. request对象 1.1 知识点 &#xff08;1&#xff09;乱码问题的两种解决方式 &#xff08;2&#xff09;post和get提交的区别 &#xff08;3&#xff09;request接收同名参数的问题 1.2 具体内容 使用request接收参数 <%page contentType"text/html; charsetut…

一个命令查看linux系统是Centos还是Ubuntu

目 录 一、 背景介绍 二、一个命令查看linux系统的简单方法 1、 uname -a 2、cat /etc/issue 3、lsb_release -a 4、 dmesg | grep Ubuntu 一、 背景介绍 Linux 系统基本上分为两大类&#xff1a; 1. Red Hat 系列&#xff1a;包括 Red Ha…

ipv6(centos布置-亲自操刀)

这一篇本来不太想写&#xff0c;但想想&#xff0c;不写出来后面又忘记了&#xff0c;就写写看了&#xff0c; 切记&#xff0c;大家看完别去用来做别的事情哈 正文来了&#xff1a; 开始就去注册一个Ipv6隧道服务吧 在隧道信息的下方有Example IPv6 Tunnel Configurations …

openEuler安装Docker艰辛路程

文章目录 安装docker测试docker关于windows docker拉取镜像查看所有镜像删除镜像删除不在运行的进程强制删除正在运行的进程 启动docker容器服务-d测试 停止docker容器服务查看docker启动进程更新容器(没有自启动功能&#xff0c;更新为自启动)docker端口映射进入容器修改内容退…

python + selenium 初步实现数据驱动

如果在进行自动化测试的时候将测试数据写在代码中&#xff0c;若测试数据有变&#xff0c;不利于数据的修改和维护。但可以尝试通过将测试数据放到excel文档中来实现测试数据的管理。 示例&#xff1a;本次涉及的项目使用的12306 selenium 重构------三层架构 excel文件数据如…

单机物理机部署Datax

一、概述 DataX 是阿里巴巴开源的一个异构数据源离线同步工具&#xff0c;致力于实现包括关系型数据库(MySQL、Oracle等)、HDFS、Hive、ODPS、HBase、FTP等各种异构数据源之间稳定高效的数据同步功能。 源码地址&#xff1a;https://github.com/alibaba/DataX 为了解决异构数据…

Portalgraph VR空间投影仪:可以将VR空间投射到任意平面上的新型VR投影技术

通过一项创新的科技突破&#xff0c;Portalgraph VR空间投影仪成功地在现实与虚拟空间之间搭建起了一座神奇的“时空传送门”。这投影一技术不仅打破了传统虚拟现实设备的局限&#xff0c;更让人们无需佩戴任何头戴显示器&#xff0c;仅凭裸眼就能在任何平面上看到虚拟现实空间…

RibbonGroup添加QAction

实际项目中&#xff0c;group中需要添加按钮与点击事件&#xff1a; 添加实例如下&#xff1a; if (Qtitan::RibbonGroup* groupClipboard pageHome->addGroup(tr("Clipboard"))) { //右下角按钮显示 groupClipboard->setO…

高效办公:在文件夹名称左边插入关键字,提高文件管理效率

在繁忙的工作环境中&#xff0c;经常要处理大量的文件和文件夹。有效的文件管理是一个挑战&#xff0c;大量的文件和文件夹难以找到所需的资料。下面一起来看云炫文件管理器如何在文件夹名称左边批量插入关键字。 文件夹名称左边添加关键字前后对比图。 文件夹名称左边批量插…

电脑扩容升级硬盘选1T还是2T

SSD固态有必要升级2TB吗&#xff1f;----------吴中函 某大二学生用的一台笔记本电脑&#xff0c;512GB的硬盘空间已经严重不够用了&#xff0c;想给笔记本扩容升级一下硬盘&#xff1b; 这位学生是学设计专业的、平时也喜欢摄影、电脑里面也装了一些游戏&#xff0c;经常整理、…

OFBiz RCE漏洞复现(CVE-2023-51467)

漏洞名称 Apache OFBiz 鉴权绕过导致命令执行 漏洞描述 Apache OFBiz是一个非常著名的电子商务平台&#xff0c;是一个非常著名的开源项目&#xff0c;提供了创建基于最新J2EE/XML规范和技术标准&#xff0c;构建大中型企业级、跨平台、跨数据库、跨应用服务器的多层、分布式…

【java八股文】之MYSQL基础篇

1、数据库三大范式是什么 第一范式&#xff1a;每个列都不可以再拆分。 第二范式&#xff1a;在第一范式的基础上&#xff0c;非主键列完全依赖于主键&#xff0c;而不能是依赖于主键的一部分。 第三范式&#xff1a;在第二范式的基础上&#xff0c;非主键列只依赖于主键&#…

数模学习day13-典型相关分析

典型相关分析&#xff08;Canonical Correlation analysis&#xff09; 研究两组变量&#xff08;每组变量中都可能有多个指标&#xff09;之间相关关系的一种多元统计方法。它能够揭示出两组变量之间的内在联系。 注&#xff1a;本文源于数学建模学习交流相关公众号观…

手把手教你在Ubuntu下建gitlab,试用于Ubuntu20、Ubuntu22、Ubuntu23

一、gitlab说明 略 二、准备工作 更新系统&#xff0c;安装依赖库$ sudo apt update && sudo apt upgrade $ sudo apt install apt install ca-certificates curl openssh-server postfix配置安装GitLab所需要的源$ curl -sS https://packages.gitlab.com/install/re…

Qt点击按钮在附近弹出下拉框

效果 MainWindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include"toollayout.h" QT_BEGIN_NAMESPACE namespace Ui { class MainWindow; } QT_END_NAMESPACEclass MainWindow : public QMainWindow {Q_OBJECTpublic:MainWindow…