【Python数据魔术】:揭秘类型奥秘,赋能代码创造

文章目录

      • 🚀一.运算符
        • 🌈1. 算术运算符
        • 🌈2. 身份运算符
        • 🌈3. 成员运算符
        • ⭐4. 增量运算符
        • ⭐5. 比较运算符
        • ⭐6. 逻辑运算符
      • 🚀二.可变与不可变
      • 🚀三.字符串转义
      • 🚀四.编码与解码
        • 💥1. 基础使用
      • 🚀五.进制转化
        • 💥1.python进制转化
      • 🚀六.深浅拷贝(复制)
        • ❤️1. 浅拷贝
        • ❤️2. 深拷贝
      • 🚀七.运算升级
      • 🚀八.常用方法
      • 🚀九.操作扩展

在这里插入图片描述

🚀一.运算符

🌈1. 算术运算符

下面以a=10 ,b=20为例进行计算

运算符描述实例
+两个对象相加 a + b 输出结果 30
-得到负数或是一个数减去另一个数 a - b 输出结果 -10
*两个数相乘或是返回一个被重复若干次的字符串 a * b 输出结果 200
/x除以y b / a 输出结果 2
//向下取整返回商的整数部分 9//2 输出结果 4 , 9.0//2.0 输出结果 4.0
%取模(余)返回除法的余数 b % a 输出结果 0
**返回x的y次幂 a**b 为10的20次方, 输出结果 100000000000000000000
🌈2. 身份运算符
  • 身份运算符
运算符描述详解
is同一性运算符变量ID是否相同,ID即变量的唯一标识,变量值可能相同但ID不一定相同
is not非同一性判断两个变量的引用是否来之不同对象
  • 使用is注意python对于小整数使用对象池存贮问题(交互式模式或者说命令行模式)
"""
1.举个例子,在python命令行模式下:为什么同样值a,b与c,d的结果却不一样呢?
"""
>>> a = 1000
>>> b = 1000
>>> a is b
False
>>> c = 10
>>> d = 10
>>> c is d
True# 注意,因为python对小整数在内存中直接创建了一份,不会回收,所有创建的小整数变量直接从对象池中引用即可。
# 但是注意Python仅仅对比较小的整数对象进行缓存(范围为范围[-5, 256])缓存起来,而并非是所有整数对象。
# 也就说只有在这个[-5,256]范围内创建的变量值使用is比较时候才会成立。
  • 而保存为文件执行,结果是不一样的,这是因为解释器做了一部分优化。即使整数超过256,使用is也是成立的。
  • 使用is注意python关于字符串的intern机制存储
# 注意: python中创建两个内容一样的变量时(变量名不一样),
#       一般都会在内存中分配两个内存地址(id地址)分别给这两个变量。
#       即两个变量的内容虽然一样,但是变量的引用地址不一样。
#       所以两个变量使用==比较成立,但是使用 is比较不成立。# 但是在python中有两个意外情况:
# 1.使用python命令行时对于小整数[-5,256]区间内的整数,python会创建小整数对象池,这些对象一旦创建,
#     就不会回收,所有新创建的在这个范围的整数都是直接引用他即可。
#     所以造成在[-5,256]区间内的整数不同变量只要值相同,引用地址也相同。
#     此范围外的整数同样遵循新建一个变量赋予一个地址。# 2.python中虽然字符串对象也是不可变对象,但python有个intern机制,
#     简单说就是维护一个字典,这个字典维护已经创建字符串(key)和它的字符串对象的地址(value),
#     每次创建字符串对象都会和这个字典比较,没有就创建,重复了就用指针进行引用就可以了。
#     相当于python对于字符串也是采用了对象池原理。
#     (但是注意:如果字符串(含有空格),不可修改,没开启intern机制,不共用对象。
#     比如"a b"和"a b",这种情况使用is不成立的形式 只有在命令行中可以。
#     使用pycharm同样是True,因为做了优化)# 交互式模式(命令行模式)
>>> a ='abc'   #没有空格内容一样的两个变量,在命令行模式下is 结果True
>>> b = 'abc'
>>> a ==b
True
>>> a is b
True
>>> c ='a b '   #有空格内容一样的两个变量,在命令行模式下is 结果false
>>> d= 'a b '
>>> c ==d
True
>>> c is d
False# pycharm自己实践
🌈3. 成员运算符
运算符描述
in如果在指定序列中找到值就返回True,否则返回False
not in如果在指定序列中没有找到值就返回True,否则返回False
str1 = [1, 2, 3, '哈哈哈']print(1 in str1)  # True
print(1 not in str1)  # False

在这里插入图片描述

⭐4. 增量运算符
运算符实例
+=c += a 等效于 c = c + a
-=c -= a 等效于 c = c - a
*=c *= a 等效于 c = c * a
/=c /= a 等效于 c = c / a
%=c %= a 等效于 c = c % a
**=c ** = a 等效于 c = c ** a
//=c //= a 等效于 c = c // a
a = 1a += 1  # 展开形式:a = a + 1print(a)  # 2

在这里插入图片描述

⭐5. 比较运算符
运算符描述
==比较两个对象的值是否相同,这里要与is区别出来,==是不识别ID的
!=比较两个对象值是否不相同
>大于
<小于
>=大于等于
<=小于等于
print(2 > 1)  # True# 比较结果为布尔值(True, False)
⭐6. 逻辑运算符
运算符逻辑表达式描述
andx and y同时满足x和y两个条件返回True,否则返回False
orx or y只需要满足x或y中的任意一个条件就返回True,两个都不满足时返回False
notnot x满足条件x时返回False,不满足条件x时返回True
  • 优先级: not and or
a = 1
b = 1
c = 2# and 两边为真则为真,其余情况为假
print(a > 0 and a < c)  # True
print(a > 1 and a < c)  # False# or 两边为假则为假, 其余情况为真
print(a > 0 and a < b)  # False
print(a == 1 and a < c)  # True# not: 取反
print(not c < a)  # True# 优先级: not and or
a = 1
b = 1
c = 2print(a > 1 and c < 3 or not a == 1) # False

在这里插入图片描述

🚀二.可变与不可变

  • 不可变(immutable):数值类型(int, bool, float,complex), 字符串(str),元组(tuple)
  • 可变(mutable):列表(list), 集合(set),字 典(dict)

🚀三.字符串转义

# 字符前存在\,在特定情况下字符就不再表示本身的意思

常见:

符号解释案例
\n换行符print(‘s\nd’)
\t水平制表符print('ss\t’dd)
\b退格(删除一格)print(‘帅 \b 不帅’)
\r当前位置移到本行开头print(‘d\rhahahs’)
\\反斜杠print(‘\\’)
\‘’一个双引号
\0一个空格符
\a系统提示音(交互界面)

字符串前面加上r就可以防止转义

# --- 交互界面 ---
>>> print('a\000c')
a c
>>> print('a\0c')
a c

🚀四.编码与解码

💥1. 基础使用
统一码(Unicode),也叫万国码、单一码,由统一码联盟开发,是计算机科学领域里的一项业界标准,包括字符集、编码方案等。
统一码是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。

encode()decode() 是常用的字符串编码和解码方法,用于将 Unicode 字符串按照指定的编码格式转换为二进制数据,并将二进制数据按照指定的编码格式解析为 Unicode 字符串。

下面是两个方法的详细说明:

  1. encode([encoding='utf-8', errors='strict'])

    该方法用于将 Unicode 字符串进行编码,生成一个包含了字符编码后的字节串对象。其中,可选参数 encoding 表示指定的字符集,如果不指定则默认采用 utf-8 编码;errors 参数用于设置错误处理方式,取值范围为 'strict''ignore''replace'

    示例代码如下:

s = "Hello, 你好"
b = s.encode(encoding="utf-8", errors="strict")
print(b)    # 输出: b'Hello, \xe4\xbd\xa0\xe5\xa5\xbd'

在这里插入图片描述

  1. decode([encoding='utf-8', errors='strict'])

    该方法用于将已经编码的二进制数据解码为 Unicode 字符串。其中,可选参数 encoding 表示待解码的字符编码,如果不指定,则默认采用 utf-8 解码;errors 参数用于设置错误处理方式,取值范围为 'strict''ignore''replace'

    示例代码如下:

b = b'Hello, \xe4\xbd\xa0\xe5\xa5\xbd'
s = b.decode(encoding="utf-8", errors="strict")
print(s)    # 输出:Hello, 你好

在这里插入图片描述

需要注意的是,字符串编码和解码涉及到多种字符编码方式和错误处理方式,如果不正确地进行设置和使用,可能会导致字符集转换错误、乱码等问题。因此,在实际开发中,应该根据具体情况选择合适的编码和解码方式,并对数据的合法性进行严格的校验和处理。

🚀五.进制转化

💥1.python进制转化

在 Python 中,可以使用内置的 bin()oct()hex() 函数将十进制数转化为二进制、八进制和十六进制字符串。

示例代码如下:

dec = 255# 十进制转二进制
bin_str = bin(dec)
print(bin_str)   # 输出 '0b11111111'# 十进制转八进制
oct_str = oct(dec)
print(oct_str)   # 输出 '0o377'# 十进制转十六进制
hex_str = hex(dec)
print(hex_str)   # 输出 '0xff'

在这里插入图片描述

需要注意的是,这些函数返回的结果都是字符串类型,并且带有对应进制的前缀,即 '0b' 表示二进制,'0o' 表示八进制,'0x' 表示十六进制。如果需要去除前缀并获取整数值,可以使用 int() 函数。

以下是一个示例代码:

# 字符串转整数(删除前缀 -- 通过切片处理)
int_val = int(bin_str[2:], 2)
print(int_val)   # 输出 255int_val = int(oct_str[2:], 8)
print(int_val)   # 输出 255int_val = int(hex_str[2:], 16)
print(int_val)   # 输出 255

在这里插入图片描述

如上所示,使用 int() 函数时可以指定第二个参数 base 来指定进制,例如 base=2 表示二进制,base=8 表示八进制,base=16 表示十六进制。在实际应用中,可以根据需要选择合适的函数和参数来进行进制转换。

# ord() 是 Python 内置函数之一,用于将ASCII字符转换为对应的 Unicode 码点。具体而言,ord() 接受一个字符串参数,表示要转换为码点的字符,然后返回该字符所对应的 Unicode 码点。
# 将字符转换为 Unicode 编码
print(ord('A'))    # 输出 65
print(ord('a'))    # 输出 97
print(ord('€'))   # 输出 8364# chr() 是 Python 内置函数之一,用于将 Unicode 码点转换为对应的ASCII字符。具体而言,chr() 接受一个整数参数,表示 Unicode 码点(介于 0 到 0x10ffff 之间),并返回与该码点相对应的字符。
# 将 Unicode 编码转换为字符
print(chr(65))    # 输出 'A'
print(chr(97))    # 输出 'a'
print(chr(8364))  # 输出 '€'

在这里插入图片描述

🚀六.深浅拷贝(复制)

❤️1. 浅拷贝

外层不受影响,内层会受影响

l1 = [1234, 5678, 910]l2 = ['a', l1]l3 = l2.copy()l1.append('帅')>>> id(l1)
1750917116360
>>> id(l2)
1750917140744
>>> id(l2[1])
1750917116360
# 内层id地址相同print(id(l2))  # 2429073232384
print(id(l2[1]))  # 2104199485056
print(id(l3))  # 2429073240128
print(id(l3[1]))  # 2104199485056# 浅复制 外层不同,内层id相同
❤️2. 深拷贝

内外层都不影响

import copy
l1 = [1234, 5678, 910]l2 = ['a', l1]l4 = copy.deepcopy(l2)l1.append('帅')print(id(l1))  # 1633334532096
print(id(l2))  # 1633334532352
print(id(l4))  # 1633334448384
print(id(l2[1]))  # 1633334532096print(id(l2[0]))  # 1633303890928
print(id(l4[0]))  # 1633303890928
print(id(l4[1]))  # 1633334532672l2[0] = 1234
print(id(l4[0]))  # 外层地址不同
print(id(l2[0]))  # 内外层都不同

🚀七.运算升级

运算符Python 表达式结果描述支持的数据类型
+[1, 2] + [3, 4][1, 2, 3, 4]合并字符串、列表、元组
*‘Hi!’ * 4[‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’]复制字符串、列表、元组
in3 in (1, 2, 3)True元素是否存在字符串、列表、元组、字典
not in4 not in (1, 2, 3)True元素是否不存在字符串、列表、元组、字典

注意,in在对字典操作时,判断的是字典的键而不是值


🚀八.常用方法

函数名描述
sum(item)计算容器中元素值的和
len(item)计算容器中元素个数
max(item)返回容器中元素最大值
min(item)返回容器中元素最小值
del(item)删除变量
# 当然还有 id,type这些常见方法# isinstance(x, A_tuple) --- 判断 x 是否是 A_tuple类型;注意A_tuple也可以是元组包多个,案例如下:print(isinstance('a', list)) # False# isinstance(x, (A, B, ...))  相当于isinstance(x, A) or isinstance(x, B) or ...

在这里插入图片描述


🚀九.操作扩展

链式赋值

a = b = c = [1, 2, 3, 4]# 其id相同,引用的同一组数据
# 改变其中一组, 另外一组也会改变

序列解包

a = [1, 2]
b, c = a
# a--1   b--2# 注意: 常规解包, 多少个元素就需要多少变量去解demo = [1, 2, 3, 4]
data, *lets = demo# data -- 1   lets -- [2, 3, 4]# 注意: 这里利用了不定长参数中的 * , 不限接收数据多少

交换变量

a = 1
b = 2b, a = a, b
# a -- 2    b -- 1

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenCv之简单的人脸识别项目(动态处理页面)

人脸识别 准备九、动态处理页面1.导入所需的包2.设置窗口2.1定义窗口外观和大小2.2设置窗口背景2.2.1设置背景图片2.2.2创建label控件 3.定义视频处理脚本4.定义相机抓取脚本5.定义关闭窗口的函数6.按钮设计6.1视频处理按钮6.2相机抓取按钮6.3返回按钮 7.定义关键函数8.动态处理…

苹果WWDC 2024 带来的 AI 风暴:从生产力工具到个人助理,AI 将如何融入我们的生活?

2024年6月5日&#xff0c;苹果WWDC 2024全球开发者大会如约而至&#xff0c;带来了众多令人兴奋的新功能和新产品。其中&#xff0c;AI 技术的全面融入无疑是最引人注目的亮点。从 iOS、iPadOS 到 macOS&#xff0c;再到 Siri 和开发者工具&#xff0c;苹果正在将 AI 融入到其生…

Linux环境各种软件安装配置

安装Java 官网 找个喜欢的版本 下载好了传到linux里&#xff0c;xshell的xftp直接拖过去就可以传 #安装rpm包管理 yum install -y rpm or apt-get install rpm #查找Java rpm -qa | grep java\|jdk\|gcj\|jre #卸载java rpm -e --nodeps jdk-1.8-1.8.0_401-10.x86_64 #安装 …

斜率优化详解

斜率优化 [HNOI2008] 玩具装箱 状态转移方程&#xff1a; f i m i n ( f i , f j ( s u m i i − s u m j − j − L ) 2 ) i > j f_imin(f_i,f_j(sum_ii-sum_j-j-L)^2){i>j} fi​min(fi​,fj​(sumi​i−sumj​−j−L)2)i>j 设A为 s u m i i sum_ii sumi​i&…

【面向就业的Linux基础】从入门到熟练,探索Linux的秘密(二)

主要内容介绍可tmux和vim的一些常用操作&#xff0c;可以当作笔记需要的时候进来查就行。 文章目录 前言 一、tmux和vim 二、Linux系统基本命令 1.tmux教程 2. vim教程 3.练习 总结 前言 主要内容介绍可tmux和vim的一些常用操作&#xff0c;可以当作笔记需要的时候进来查就行…

双非本科一年20w,已是人中龙凤了

大家好&#xff0c;我是白露啊。 “双非本科一年20w已经是人中龙凤了”……吗&#xff1f; 牛客上刷到这条帖子&#xff0c;我一开始以为是一个钓鱼、引战贴。看完才觉得他说的很对&#xff0c;现在在求职选择工作的时候&#xff0c;网上都觉得得40万、50万&#xff0c;但当真…

Next.js Tailwind CSS UI组件

摘要&#xff1a; 官网 今天公司使用到一个前端ui框架——Next.js Tailwind CSS UI组件&#xff01;这从头构建一个AI驱动的前端UI组件生成器&#xff0c;生成Next.js Tailwind CSS UI组件&#xff1a; 1、用Next.js、ts和Tailwind CSS构建UI组件生成器Web应用程序。 2、用Copi…

LVGL欢乐桌球游戏(LVGL+2D物理引擎学习案例)

LVGL欢乐桌球游戏&#xff08;LVGL2D物理引擎学习案例&#xff09; 视频效果&#xff1a; https://www.bilibili.com/video/BV1if421X7DL

UFS协议入门-分层结构

写在前面:本文参考UFS jedec3.1,本文思维导图如下 1. 分层概述 UFS协议分为3层,从上至下分别是:应用层(UAP),传输层(UTP),互联层(UIC),具体结构如下图所示。 2.1 应用层 在应用层(UAP)中,包括:UFS指令集(UCS),设备管理器(Device Manager),任务管理器(Task Manager…

MeiliSearch-轻量级且美丽的搜索引擎

MeiliSearch-轻量级且美丽的搜索引擎 MeiliSearch 是一个功能强大、快速、开源、易于使用和部署的搜索引擎。它具有以下特点&#xff1a; 支持中文搜索&#xff1a;MeiliSearch 对中文有良好的支持&#xff0c;不需要额外的配置。高度可定制&#xff1a;搜索和索引都可以高度…

GPT-4o多模态大模型的架构设计

GPT-4o&#xff1a;大模型风向&#xff0c;OpenAI大更新 OpenAI震撼发布两大更新&#xff01;桌面版APP与全新UI的ChatGPT上线&#xff0c;简化用户操作&#xff0c;体验更自然。同时&#xff0c;全能模型GPT-4o惊艳亮相&#xff0c;跨模态即时响应&#xff0c;性能卓越且性价比…

计算机网络 期末复习(谢希仁版本)第3章

对于点对点的链路&#xff0c;目前使用得最广泛的数据链路层协议是点对点协议 PPP (Point-to-Point Protocol)。局域网的传输媒体&#xff0c;包括有线传输媒体和无线传输媒体两个大类&#xff0c;那么有线传输媒体有同轴电缆、双绞线和光纤&#xff1b;无线传输媒体有微波、红…

Flink的简单学习五

一 动态表与连续查询 1.1 动态表 1.是flink的支持流数据Table API 和SQL的核心概念。动态表随时间的变化而变化 2.在流上面定义的表在内部是没有数据的 1.2 连续查询 1.永远不会停止&#xff0c;结果是一张动态表 二 Flink SQL 2.1 sql行 1.先启动启动flink集群 yarn-see…

全球首创4090推理!昆仑万维开源Skywork-MoE模型

昆仑万维近期宣布开源了其2千亿参数规模的稀疏大模型Skywork-MoE。这个模型是基于他们之前开源的Skywork-13B模型中间checkpoint扩展而来的&#xff0c;并且宣称是首个完整应用MoE Upcycling技术的开源千亿MoE大模型。此外&#xff0c;它也是首个支持使用单台RTX 4090服务器&am…

SpringSecurity入门(一)

1、引入依赖 spring-boot版本2.7.3&#xff0c;如未特殊说明版本默认使用此版本 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId></dependency><dependency><g…

16 DTLS协议

加密解密基本概念 什么是非对称加密 什么是公钥 这个就是谁都能获得的钥匙什么是私钥 只有一个人能获得 非对称加密就是公钥上的锁&#xff0c;私钥才能打开&#xff0c;私钥上的锁公钥才能打开。比如说就是地下党接头的时候&#xff0c;把一个信息放在盒子里&#xff0c;然…

大数据概论总结

三次信息化浪潮 : 信息技术的支撑 : 存储设备容量不断增加 CPU的处理能力不断提高 网络带宽不断增加 数据产生方式的变革促成大数据时代的来临 运营式系统阶段用户原创内容感知式系统阶段 大数据发展历程 : 分为三个阶段 : 大数据的概念 : 1 . 数据量大 : 根据IDC作出…

每日一练:攻防世界:base64stego

base64stego&#xff1a; 打开压缩包发现被加密&#xff0c;用winhex查看&#xff0c;发现是伪加密&#xff0c;修改文件目录区的全局方式位标记&#xff0c;成功打开压缩包&#xff0c;得到一个文本 这里我想的有三种情况&#xff1a;1.直接base64解码&#xff0c;然后看解码…

【计网复习】应用层总结(不含HTTP和错题重点解析)

应用层总结&#xff08;不含HTTP和错题重点解析&#xff09; 应用层简介 应用层的主要功能常见的应用层协议小林对于应用层通常的解释 网络应用模型 客户端-服务器模型&#xff08;Client-Server Model, C/S&#xff09; 特点优点缺点应用场景 对等网络模型&#xff08;Peer-to…

第十五篇——条件熵和信息增益:你提供的信息到底值多少钱?

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么&#xff1f; 四、总结五、升华 一、背景介绍 通过这篇文章&#xff0c;我知道了条件熵和信息增益&#xff1b;如果你试…