【Python】基本使用

news2024/9/23 15:23:37

目录

变量的类型

整数 int

浮点数 float

字符串 str

字符串长度

格式化字符串

布尔类型  

动态类型

注释 

获取输入

浮点数比较

多元赋值

for循环

函数的定义和调用

创建函数/定义函数

调用函数/使用函数

列表

创建列表

切片操作

遍历列表

新增元素

判断元素是否在列表中

删除元素

连接列表

元组

创建元组

指定初始值

下标访问

切片操作

循环遍历 

 in判断元素是否存在,index获取下标

使用+拼接两个元组


变量的类型

在python中,变量的类型不需要在定义变量的时候显式声明,而是依靠初始化语句,根据初始化的值的类型来进行确定的。如下示例:

输出一个变量的类型

a=10
print(type(a))

输出如下所示: 

整数 int

在Python中,int能够表示的数据范围,是“无穷”的,与C++、Java的int不一样。Python的int是可以根据要表示的数据的大小,自动扩容。因此python中,整数只有int类型。

浮点数 float

C++和Java里面的float是四个字节,也叫做“单精度浮点数”,在Python中,float等同于C++和Java中的double。

字符串 str

Python中,使用引号把一系列字符引起来,就构成了字符串,引号用 ‘’ 或 "" 都可以的。 

如果字符串内需要包含引号,外面的引号用另一种引号即可

a='123"456"'

字符串长度

获取字符串长度可以通过len()方法

a='123"456"'
print(len(a))

格式化字符串

 当我们希望打印出 a=10 这样的内容,也就是a这个变量的值是可变的。

a=10
print(f"a={a}")

 这种语法,叫做“格式化字符串”,使用{}这样的语法,往字符串里嵌入变量或者表达式

布尔类型  

只有两种取值 True、False,主要用于逻辑判定,这里与C++不同的是开头字母大写

动态类型

程序运行过程中,变量的类型可能会发生改变

如下代码:

a=10
print(type(a))
a='hello'
print(type(a))
a=True
print(type(a))

结果如下: 

一个编程语言,是否是动态类型,只是取决于运行时,类型是否发生改变,不取决于变量定义的时候是否声明类型! 

注释 

有两种注释方式

第一种:注释行

使用#开头的行都是注释

#这是一行注释

# 开头的注释,一般是写在要注释的代码的上方,也有少数写在代码的右侧

第二种 :文档字符串

使用三引号引起来的称为“文档字符串”,也可以视为是一种注释。

  • 可以包含多行内容
  • 一般放在文件/函数/类的开头
  • """ 或者 "" 均可(等价)

"""
这是一段文档字符串
这是一段文档字符串
"""

获取输入

num=input("请输入一个整数:")
print(f"输入的整数是:{num}")

input的返回值,是一个str ,如果要对这个读取的str进行算术运算,可以通过int()进行转换

整数转字符串str()

字符串转浮点数float() 

浮点数比较

在python中浮点数直接进行比较的话,可能不会返回正确的结果。

a=0.1
b=0.2
print(a+b==0.3)

例如上述的代码返回的结果是false,因为浮点数在内存中的存储和表示,是可能存在误差的,这样的误差在进行算术运算的时候就可能被放大,从而导致 == 的判定出现误判

print(a+b)
print(0.3)

我们可以输出a+b的结果和0.3进行对比,如下:

0.30000000000000004
0.3

因此我们可以通过两个数的差是否在误差范围之内,判断两个数是否相等

print(-0.000001<(a+b-0.3)<0.000001)

上述返回的结果是true

多元赋值

a,b=10,20
print(a)
print(b)

上述代码将10赋值给a,20赋值给b。

多元赋值还可用在交换两个数的值

a,b=10,20

a,b=b,a
print(a)
print(b)

需要注意的是,python中不支持++、--的自增自减操作 

for循环

基本语法格式

for 循环变量 in 可迭代对象:

        循环体

  • python的for和其他语言不同,没有初始化语句,循环条件判断语句,循环变量更新语句,而是更加简单。
  • 所谓的可迭代对象,只的是内部包含多个元素,能一个一个把元素取出来的特殊变量。 

代码示例:打印1-10

for i in range(1,11) :

        print(i)

使用range函数,能够生成一个可迭代对象,生成的范围是[1,11),左闭右开

代码示例:打印2、4、6、8、10

for i in range(2,12,2)

        print(i)

range还提供第三个参数,表示“步长”默认的步长是1,这个步长可以是整数也可以是负数

  • shift+F6可以针对变量进行重命名,会自动的把所有要修改的名字都替换

函数的定义和调用

创建函数/定义函数

def 函数名(形参列表):

        函数体

        return 返回值

调用函数/使用函数

函数名(实参列表)                            //不考虑返回值

返回值=函数名(实参列表)                //考虑返回值 

python一个函数可以返回多个值

示例:

def test():
    return 1,2,3

x,y,z=test()

在函数内部需要修改全局变量的话,需要引入global关键字

x=10

def test():

        x=20

 print(f"x={x}")

如上所示,输出结果是x=10,因为在函数内部x=20,被看作是创建了一个x变量,因此要对全局的x进行修改,需如下所示:

x=10

def test():

        global x

        x=20

 print(f"x={x}")

 for循环不影响变量的作用域,只有函数,类才影响作用域

for i in range(1,11)

        print(i)

print(i)

列表

列表和元组类似于其他编程语言中的“数组”

列表和元组之间的区别:

  • 列表是可变的,创建好了之后,随时能改(散装辣条)
  • 元组是不可变的,创建好了之后,改不了,要想改,只能丢弃旧的,搞一个新的(包装辣条)

创建列表

空列表

a=[]     a=[1,2,3]

b=list()

c++/java里面要求一个数组里面只能存相同类型的变量,python中列表可以放不同类型的变量 

(1) 可以用内建函数len来获取到列表的长度

len(a)

(2) python中的下标,还可以写成负数

例如[-1]等价于[len(a)-1]

切片操作

通过下标操作是以此取出里面第一个元素

通过切片,则是一次取出一组连续的元素,相当于得到一个子列表

  • 使用[ :]的方式进行切片操作

alist=[1,2,3,4]

print(alist[1:3])

  • [1:3]表示的是[1,3)这样由下标构成的前闭后开区间
  • 最终结果为2,3
  • 进行切片的时候,可以省略边界

 alist=[1,2,3,4]

print(alist[1:])

  • 省略后边界,意思是从开始位置,一直取到整个列表结束
  • 省略前边界,意思是从列表的0号元素开始取,一直取到结束的边界
  • 前后边界都省略掉,得到的就是列表自身
  • 切片操作还可以指定步长

 alist=[1,2,3,4]

print(alist[ ::1 ])

  • 1的意思是,每隔一个元素取一个元素
  • 示例:

  • 还可以这样print(alist[ 1:-1:2 ])进行切片
  • 步长的数值还可以是负数,当步长是负数的时候,意思是从后往前遍历元素
  • 当切片中的范围超出有效下标之后,不会出现异常,而是尽可能把符合要求的元素获取到

遍历列表

第一种:不通过下标来访问元素

示例:

a=[1,2,3,4,5]

for elem in a:

        print(elem)

这种方式通过elem取出列表元素,对elem修改不会影响到原来的a数组

第二种:通过下标来访问元素

示例:

a=[1,2,3,4,5]

for i in range(0,len(a))

        print(a[i])

这种方式通过下标取出列表元素,对elem修改会影响到原来的a数组

新增元素

1、通过append方式往列表末尾新增一个元素

a=[1,2,3,4]

a.append(5)

print(a)

结果如下:

2、还可以使用insert方法,往列表的任意位置来新增元素

a=[1,2,3,4]

a.insert(1,'hello')

print(a) 

结果如下:

如果插入下标超过列表长度,插入的元素直接添加在列表的末尾

判断元素是否在列表中

1、使用in来判定某个元素是否在列表中。

a=[1,2,3,4]

print(1 in a)

print(10 in a)

结果如下:

与in相对应的还有一个not in

print(1 not in a)

判断1是否不在a中

 2、使用index方法,来判定,当前元素在列表中的位置,得到一个下标

a=[1,2,3,4]

print(a.index(2))

print(a.index(10)) //若元素不在列表中,抛出异常

删除元素

 1、使用pop方法删除最末尾元素

alist=[1,2,3,4]

alist.pop()

2、pop也可以按照下标来删除元素

alist=[1,2,3,4]

alist.pop(2)

print(alist)

结果如下:

3、使用remove方法删除对应值的元素

alist=[1,2,3,4]

alist.remove(2)

连接列表

1、使用+能够把两个列表拼接在一起

此处的+结果会生成一个新的新列表,而不会影响旧列表的内容

alist=[1,2,3,4]

blist=[5,6,7]

print(alist+blist)

结果如下:

2、使用extend拼接(效率比较高)

这个拼接是把后一个列表的内容拼接到前一个列表里 

extend方法没有返回值

alist=[1,2,3,4]

blist=[5,6,7]

c=alist.extend(blist)

print(alist)

print(blist)

print(c)

结果如下:

  • python中"None"这是一个特殊的变量的值,表示啥都没有

3、使用+=进行拼接

alist=[1,2,3,4]

blist=[5,6,7]

alist+=blist

print(alist)

结果如下:

元组

创建元组

创建元组有两种方法:

//1.方法1

a=()

//2.方法2

b=tuple()

指定初始值

创建元组时可以指定初始值,元组中的元素也可以是任意类型

a=(1,2,3,4,5)

下标访问

也可以通过下标访问元组的元素 ,越界也是抛异常

a=(1,2,3,4,5)
print(a[1])

切片操作

a=(1,2,3,4,5)
print(a[1:3])

循环遍历 

a=(1,2,3,4,5)
for elem in a:
    print(elem)

 in判断元素是否存在,index获取下标

a=(1,2,3,4,5)

print(3 in a)


print(a.index(3))

使用+拼接两个元组

a=(1,2,3)
b=(4,5,6)
print(a+b)

元组只支持读操作,不支持改操作,因此不支持pop,extend,append方法

当进行多元赋值的时候,其实本质上就是按照元组的方式进行工作的

def getPoint():
    x=1
    y=2
    return x,y

print(type(getPoint()))

结果如下:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024上半年国产操作系统卖疯了!麒麟4.9亿,统信1.9亿!

昨天一篇关于国产数据库上市公司的财报分析&#xff0c;没想到还小&#x1f525;了一把。实际上国产数据库与操作系统是密不可分的&#xff0c;既然用户要进行全面国产化&#xff0c;那么除了数据库&#xff0c;底层服务器操作系统&#xff0c; 一定也会是国产操作系统。 从20…

JavaScript事件处理和常用对象

文章目录 前言一、事件处理程序 1.JavaScript 常用事件2.事件处理程序的调用二、常用对象 1.Window 对象2.String 对象3.Date 对象总结 前言 JavaScript 语言是事件驱动型的。这意味着&#xff0c;该门语言可以通过事件触发来调用某一函数或者一段代码。该文还简单介绍了Window…

讨论人机交互研究中大语言模型的整合与伦理问题

概述 论文地址&#xff1a;https://arxiv.org/pdf/2403.19876.pdf 近年来&#xff0c;大规模语言模型发展迅速。它们给研究和教育领域带来了许多变化。这些模型也是对人机交互&#xff08;HCI&#xff09;研究过程的有力补充&#xff0c;可以分析定性和定量数据&#xff0c;再…

4.C_数据结构_队列

概述 什么是队列&#xff1a; 队列是限定在两端进行插入操作和删除操作的线性表。具有先入先出(FIFO)的特点 相关名词&#xff1a; 队尾&#xff1a;写入数据的一段队头&#xff1a;读取数据的一段空队&#xff1a;队列中没有数据&#xff0c;队头指针 队尾指针满队&#…

springboot 整合quartz定时任务

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、pom的配置1.加注解 二、使用方法1.工程图2.创建工具类 三、controller 实现 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 提示&a…

微服务、云计算、分布式开发全套课程课件,来原于企培和多年大厂工作提炼

本课内容为笔者16年企业工作期间企培经验总结的 全套课件。需要自取&#xff0c;已分块和整体上传至资源下载中。 全部来源于笔者多年企业培训迭代整理&#xff0c;并做了特殊处理&#xff0c;所以内容无涉密和版权麻烦。 课件内容全部来源于笔者在京东、58、阿里&#xff1b;中…

第二百三十二节 JPA教程 - JPA教程 - JPA ID自动生成器示例、JPA ID生成策略示例

JPA教程 - JPA ID自动生成器示例 我们可以将id字段标记为自动生成的主键列。 数据库将在插入时自动为id字段生成一个值数据到表。 例子 下面的代码来自Person.java。 package cn.w3cschool.common;import javax.persistence.Entity; import javax.persistence.GeneratedValu…

java内存概述

运行时数据区域 Java 虚拟机在执行 Java 程序的过程中会把它所管理的内存划分为若干个不同的数据区域。这些区域有各自的用途&#xff0c;以及创建和销毁的时间&#xff0c;有的区域随着虚拟机进程的启 动而一直存在&#xff0c;有些区域则是依赖用户线程的启动和结束而建立和…

charls基于夜神模拟器抓取安卓7.0应用程序https请求

charls基于夜神模拟器抓取安卓7.0应用程序https请求 1、安装charls&#xff08;安装步骤这里就不详细说了&#xff09;2、下载证书&#xff08;证书后缀名 xx.pem&#xff09;3、使用git bash生成证书hash4、上传证书到安卓的系统证书目录下&#xff08;夜神模拟器方案&#xf…

C++速通LeetCode简单第9题-二叉树的最大深度

深度优先算法递归&#xff1a; /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right…

屏幕缺陷检测-目标检测数据集(包括VOC格式、YOLO格式)

屏幕缺陷检测-目标检测数据集&#xff08;包括VOC格式、YOLO格式&#xff09; 数据集&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1mb83CzAAOkvMZ_LS9Alt8w?pwdagi6 提取码&#xff1a;agi6 数据集信息介绍&#xff1a; 共有 3789 张图像和一一对应的标注文件 标…

RPC远程调用的序列化框架

序列化框架对比&#xff1a; 一、Java Serialiazer 字段serialVersionUID的作用是为了在序列化时保持版本的兼容性&#xff0c;即版本升级时反序列化仍保持对象的唯一性。 //序列化 ByteArrayOutputStream bout new ByteArrayOutputStream(); ObjectOutoutStream out new O…

【Kubernetes笔记】为什么DNS解析会超时?

【Kubernetes笔记】为什么DNS解析会超时&#xff1f; 目录 1 问题背景2 产生后续的问题3 DNS 负缓存工作原理&#xff1a;4 如何解决和缓解 DNS 负缓存 4.1 减小负缓存 TTL4.2 重试机制4.3 减少 Pod 的频繁重启或调度4.4 使用 Headless Service4.5 手动刷新 DNS 缓存 5 总结 …

苹果cms多语言插件,插件配置前端默认语言采集语言等

苹果CMS&#xff08;maccmscn&#xff09;是一款功能强大的内容管理系统&#xff0c;广泛应用于视频网站和其他内容发布平台。为了满足全球用户的需求&#xff0c;苹果CMS支持多语言插件&#xff0c;使得网站能够方便地提供多语言版本。以下是关于苹果CMS多语言插件的详细介绍&…

网络原理2-网络层与数据链路层

目录 网络层数据链路层 网络层 网络层做的工作&#xff1a; 1、地址管理–>IP地址 2、路由选择–>数据包传输的路径规划 网络层主要的协议就是IP协议 IP协议的报头结构&#xff1a; 4位版本&#xff1a; 有两个取值&#xff0c;4表示IPv4&#xff0c;6表示IPv6&am…

关于网站ERR_TOO_MANY_REDIRECTS错误的修改办法

今天网站因为证书到期&#xff0c;七牛云的报错一直ERR_TOO_MANY_REDIRECTS&#xff0c;302重定向次数过多了&#xff0c;连后台都进不去 多次清除cookie未果&#xff0c;终于找到了原因&#xff1a;设置了太多重定向&#xff0c; 1.http强制跳转 2.宝塔后台设置了跳转 3.域…

备战软考Day02-数据结构与算法

1.基本概念与三要素 1.什么是数据 数据是信息的载体&#xff0c;是描述客观事物属性的数、字符及所有能输入到计算机中并被计算机程序识别和处理的符号的集合。数据是计算机程序加工的原料。 2.数据元素、数据项 数据元素是数据的基本单位&#xff0c;通常作为一个整体进行…

树莓派Pico2(RP2350)开发环境搭建

树莓派Pico2(RP2350)开发环境搭建 文章目录 树莓派Pico2(RP2350)开发环境搭建1、RP2350介绍2、开发环境搭建3、工程编译4、固件下载Raspberry Pi再次通过推出RP2350 MCU突破了微控制器设计的界限。这款微控制器是之前RP2040的重大升级,带来了更强大的性能、高级安全功能,…

基于SSM的二手车管理系统的设计与实现 (含源码+sql+视频导入教程)

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 基于SSM的二手车管理系统4拥有三种角色 管理员&#xff1a;订单管理、在售车辆管理、下架车辆管理、品牌管理、分类管理、推荐管理、统计等 商家&#xff1a;登录注册、添加/下架/删除车辆…

vscode搭建ros开发环境问题记录(更新...)

文章目录 vscode 不能自动补全 开发环境&#xff1a; vmware 15.7 ubuntu 20.04 ros noetic vscode 不能自动补全 这里将头文件已经正确包含到c_cpp_properties.json中代码中仍然不能自动补全&#xff0c; 将C_CPP插件设置中的Intelli Sense Engine 设置为TagParser,然后重新加…