当前位置: 首页 > news >正文

深入理解Python常见数据类型处理

目录

  1. 概述
  2. 数字类型
    • 整数(int)
    • 浮点数(float)
    • 复数(complex)
  3. 字符串(str)
    • 字符串基本操作
    • 字符串方法
  4. 列表(list)
    • 列表基本操作
    • 列表方法
    • 列表推导式
  5. 元组(tuple)
    • 元组基本操作
    • 元组方法
  6. 字典(dict)
    • 字典基本操作
    • 字典方法
    • 字典推导式
  7. 集合(set)
    • 集合基本操作
    • 集合方法
    • 集合推导式
  8. 总结

概述

Python中的数据类型可以分为几大类:数字类型、序列类型(如字符串、列表、元组)、映射类型(如字典)和集合类型。这些数据类型不仅具有丰富的内置方法,还支持各种运算符和表达式,使得数据处理变得简单而高效。

数字类型

数字类型是Python中最基本的数据类型,包括整数、浮点数和复数。

整数(int)

整数类型用于表示没有小数部分的数值,支持各种算术运算。

a = 10
b = 3# 加法
print(a + b)  # 13# 减法
print(a - b)  # 7# 乘法
print(a * b)  # 30# 除法
print(a / b)  # 3.3333333333333335# 地板除法
print(a // b)  # 3# 取余
print(a % b)  # 1# 幂运算
print(a ** b)  # 1000

浮点数(float)

浮点数用于表示有小数部分的数值,支持同样的算术运算。

x = 10.5
y = 2.3# 加法
print(x + y)  # 12.8# 减法
print(x - y)  # 8.2# 乘法
print(x * y)  # 24.15# 除法
print(x / y)  # 4.565217391304348

复数(complex)

复数由实部和虚部组成,表示为a + bj

z1 = 2 + 3j
z2 = 1 - 1j# 加法
print(z1 + z2)  # (3+2j)# 减法
print(z1 - z2)  # (1+4j)# 乘法
print(z1 * z2)  # (5+1j)# 除法
print(z1 / z2)  # (-0.5+2.5j)

字符串(str)

字符串是Python中处理文本数据的基本类型。字符串是不可变序列类型,支持各种操作和方法。

字符串基本操作

s = "Hello, World!"# 访问字符
print(s[0])  # 'H'
print(s[-1])  # '!'# 切片
print(s[0:5])  # 'Hello'
print(s[7:])  # 'World!'
print(s[-6:])  # 'World!'# 拼接
s1 = "Hello"
s2 = "World"
print(s1 + ", " + s2 + "!")  # 'Hello, World!'# 重复
print(s1 * 3)  # 'HelloHelloHello'# 查找
print(s.find("World"))  # 7
print(s.find("Python"))  # -1

字符串方法

Python提供了丰富的字符串方法,下面列举一些常用的。

# 转换大小写
print(s.upper())  # 'HELLO, WORLD!'
print(s.lower())  # 'hello, world!'
print(s.capitalize())  # 'Hello, world!'# 替换
print(s.replace("World", "Python"))  # 'Hello, Python!'# 拆分
print(s.split(", "))  # ['Hello', 'World!']# 去除空白
s3 = "  Hello, World!  "
print(s3.strip())  # 'Hello, World!'# 检查字符串开头和结尾
print(s.startswith("Hello"))  # True
print(s.endswith("!"))  # True# 格式化
name = "Alice"
age = 30
print(f"Name: {name}, Age: {age}")  # 'Name: Alice, Age: 30'

列表(list)

列表是Python中最常用的序列类型,支持存储任意类型的对象。

列表基本操作

lst = [1, 2, 3, 4, 5]# 访问元素
print(lst[0])  # 1
print(lst[-1])  # 5# 切片
print(lst[1:3])  # [2, 3]
print(lst[:3])  # [1, 2, 3]
print(lst[3:])  # [4, 5]# 修改元素
lst[0] = 10
print(lst)  # [10, 2, 3, 4, 5]# 添加元素
lst.append(6)
print(lst)  # [10, 2, 3, 4, 5, 6]# 删除元素
lst.remove(10)
print(lst)  # [2, 3, 4, 5, 6]# 列表长度
print(len(lst))  # 5

列表方法

列表提供了许多内置方法,以下是一些常用的。

# 插入元素
lst.insert(1, 9)
print(lst)  # [2, 9, 3, 4, 5, 6]# 弹出元素
print(lst.pop())  # 6
print(lst)  # [2, 9, 3, 4, 5]# 排序
lst.sort()
print(lst)  # [2, 3, 4, 5, 9]# 反转
lst.reverse()
print(lst)  # [9, 5, 4, 3, 2]# 计数
print(lst.count(3))  # 1# 清空列表
lst.clear()
print(lst)  # []

列表推导式

列表推导式是一种简洁的创建列表的方式。

# 创建一个包含0到9的平方数的列表
squares = [x ** 2 for x in range(10)]
print(squares)  # [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]# 创建一个包含偶数的列表
evens = [x for x in range(10) if x % 2 == 0]
print(evens)  # [0, 2, 4, 6, 8]

元组(tuple)

元组是不可变的序列类型,适合存储不可变的数据。

元组基本操作

t = (1, 2, 3, 4, 5)# 访问元素
print(t[0])  # 1
print(t[-1])  # 5# 切片
print(t[1:3])  # (2, 3)
print(t[:3])  # (1, 2, 3)
print(t[3:])  # (4, 5)# 元组长度
print(len(t))  # 5

元组方法

由于元组是不可变的,它的方法相对较少。

# 计数
print(t.count(2))  # 1# 查找索引
print(t.index(3))  # 2

字典(dict)

字典是一种键值对的集合,是Python中最常用的映射类型。

字典基本操作

d = {'name': 'Alice', 'age': 30, 'city': 'New York'}# 访问元素
print(d['name'])  # 'Alice'# 修改元素
d['age'] = 31
print(d)  # {'name': 'Alice', 'age': 31, 'city': 'New York'}# 添加元素
d['email'] = 'alice@example.com'
print(d)  # {'name': 'Alice', 'age': 31, 'city': 'New York', 'email': 'alice@example.com'}# 删除元素
del d['city']
print(d)  # {'name': 'Alice', 'age': 31, 'email': 'alice@example.com'}

字典方法

字典提供了丰富的内置方法,以下是一些常用的。

# 获取所有键
print(d.keys())  # dict_keys(['name', 'age', 'email'])# 获取所有值
print(d.values())  # dict_values(['Alice', 31, 'alice@example.com'])# 获取所有键值对
print(d.items())  # dict_items([('name', 'Alice'), ('age', 31), ('email', 'alice@example.com')])# 使用get方法访问键,避免KeyError
print(d.get('name'))  # 'Alice'
print(d.get('address', 'Not Found'))  # 'Not Found'# 清空字典
d.clear()
print(d)  # {}

字典推导式

字典推导式是一种简洁的创建字典的方式。

# 创建一个键为0到9,值为平方数的字典
squares_dict = {x: x ** 2 for x in range(10)}
print(squares_dict)  # {0: 0, 1: 1, 2: 4, 3: 9, 4: 16, 5: 25, 6: 36, 7: 49, 8: 64, 9: 81}

集合(set)

集合是一种无序且不重复的元素集合,适合用于去重和集合运算。

集合基本操作

s = {1, 2, 3, 4, 5}# 添加元素
s.add(6)
print(s)  # {1, 2, 3, 4, 5, 6}# 删除元素
s.remove(3)
print(s)  # {1, 2, 4, 5, 6}# 检查元素是否存在
print(4 in s)  # True
print(10 in s)  # False# 集合长度
print(len(s))  # 5

集合方法

集合支持各种集合运算和方法。

# 交集
s1 = {1, 2, 3}
s2 = {3, 4, 5}
print(s1 & s2)  # {3}# 并集
print(s1 | s2)  # {1, 2, 3, 4, 5}# 差集
print(s1 - s2)  # {1, 2}# 对称差集
print(s1 ^ s2)  # {1, 2, 3, 4, 5}# 子集和超集
s3 = {1, 2}
print(s3.issubset(s1))  # True
print(s1.issuperset(s3))  # True# 集合复制
s_copy = s1.copy()
print(s_copy)  # {1, 2, 3}

集合推导式

集合推导式类似于列表和字典推导式,是一种快速生成集合的方式。

# 创建一个包含偶数的集合
evens_set = {x for x in range(10) if x % 2 == 0}
print(evens_set)  # {0, 2, 4, 6, 8}

数据类型转换

Python提供了多种内置函数来进行不同数据类型之间的转换。了解如何进行数据类型转换可以帮助我们在编写代码时更灵活地处理数据。

转换为整数

使用 int() 函数可以将其他类型转换为整数类型。

# 从字符串转换为整数
a = int("10")
print(a)  # 10# 从浮点数转换为整数
b = int(10.6)
print(b)  # 10# 从复数转换为整数会报错
# c = int(10 + 5j)  # TypeError: can't convert complex to int

转换为浮点数

使用 float() 函数可以将其他类型转换为浮点数类型。

# 从字符串转换为浮点数
x = float("10.5")
print(x)  # 10.5# 从整数转换为浮点数
y = float(10)
print(y)  # 10.0

转换为字符串

使用 str() 函数可以将其他类型转换为字符串类型。

# 将整数转换为字符串
a = str(10)
print(a)  # "10"# 将浮点数转换为字符串
b = str(10.5)
print(b)  # "10.5"# 将列表转换为字符串
lst = [1, 2, 3]
print(str(lst))  # "[1, 2, 3]"

转换为列表

使用 list() 函数可以将其他可迭代类型(如字符串、元组)转换为列表类型。

# 将字符串转换为列表
s = "hello"
print(list(s))  # ['h', 'e', 'l', 'l', 'o']# 将元组转换为列表
t = (1, 2, 3)
print(list(t))  # [1, 2, 3]

转换为元组

使用 tuple() 函数可以将其他可迭代类型转换为元组类型。

# 将字符串转换为元组
s = "hello"
print(tuple(s))  # ('h', 'e', 'l', 'l', 'o')# 将列表转换为元组
lst = [1, 2, 3]
print(tuple(lst))  # (1, 2, 3)

转换为字典

使用 dict() 函数可以将特定格式的可迭代类型转换为字典类型。

# 将列表转换为字典
pairs = [("name", "Alice"), ("age", 30)]
d = dict(pairs)
print(d)  # {'name': 'Alice', 'age': 30}

转换为集合

使用 set() 函数可以将其他可迭代类型转换为集合类型。

# 将字符串转换为集合
s = "hello"
print(set(s))  # {'o', 'h', 'e', 'l'}# 将列表转换为集合
lst = [1, 2, 2, 3, 3]
print(set(lst))  # {1, 2, 3}

数据类型的常见应用场景

理解数据类型不仅仅是掌握其基本操作和方法,还要知道如何在实际编程中使用它们。接下来我们讨论一些常见的数据类型应用场景。

数字类型的应用场景

数字类型在数学计算、统计分析、物理模拟等领域应用广泛。比如,在金融领域,我们常常使用浮点数进行货币计算。

# 计算年利率
principal = 1000  # 本金
rate = 0.05  # 年利率
years = 5
amount = principal * (1 + rate) ** years
print(f"After {years} years, the amount will be {amount:.2f}")

字符串的应用场景

字符串在文本处理、日志记录、用户输入输出等场景中扮演着重要角色。比如,在自然语言处理(NLP)领域,我们会频繁地对字符串进行操作。

# 统计文本中的单词数量
text = "Python is an amazing programming language."
word_count = len(text.split())
print(f"The text contains {word_count} words.")

列表的应用场景

列表在存储和处理有序数据时非常有用,如存储用户输入的数据、处理批量数据等。

# 统计班级学生的平均成绩
scores = [85, 90, 78, 92, 88]
average_score = sum(scores) / len(scores)
print(f"The average score of the class is {average_score:.2f}")

元组的应用场景

元组在需要存储不可变数据时非常有用,如存储常量、坐标等。

# 表示二维空间的一个点
point = (10, 20)
print(f"The point is located at {point}")

字典的应用场景

字典在处理键值对数据时非常有用,如存储配置参数、用户信息等。

# 存储用户信息
user_info = {'name': 'Alice', 'age': 30, 'email': 'alice@example.com'}
print(f"User {user_info['name']} is {user_info['age']} years old.")

集合的应用场景

集合在处理无序且不重复的元素集合时非常有用,如去重、集合运算等。

# 去除列表中的重复元素
numbers = [1, 2, 2, 3, 4, 4, 5]
unique_numbers = list(set(numbers))
print(f"Unique numbers: {unique_numbers}")

数据类型的性能考量

在实际编程中,选择合适的数据类型不仅影响代码的可读性和可维护性,还会影响程序的性能。以下是一些性能考量的例子。

列表 vs 元组

虽然列表和元组在很多操作上是类似的,但列表是可变的,而元组是不可变的。在需要频繁修改数据时,使用列表更合适;在需要保护数据不被修改时,使用元组更安全。

另外,元组由于不可变,通常比列表占用更少的内存,操作速度也更快。

import timeit# 测试列表和元组的创建速度
list_time = timeit.timeit(stmt="[1, 2, 3, 4, 5]", number=1000000)
tuple_time = timeit.timeit(stmt="(1, 2, 3, 4, 5)", number=1000000)print(f"List creation time: {list_time}")
print(f"Tuple creation time: {tuple_time}")

字典的查找性能

字典使用哈希表来存储数据,因此查找操作非常高效,通常是O(1)时间复杂度。对于大规模的数据,字典的查找性能远优于列表的线性查找。

# 测试字典和列表的查找性能
d = {i: i for i in range(10000)}
lst = [i for i in range(10000)]dict_time = timeit.timeit(stmt="9999 in d", setup="from __main__ import d", number=1000000)
list_time = timeit.timeit(stmt="9999 in lst", setup="from __main__ import lst", number=1000000)print(f"Dict lookup time: {dict_time}")
print(f"List lookup time: {list_time}")

总结

在Python编程中,数据类型的选择和使用至关重要。本文详细介绍了Python中常见的数据类型及其基本操作、内置方法、转换方法,并通过代码示例和应用场景帮助读者加深理解。在实际开发中,选择合适的数据类型不仅能提高代码的可读性和可维护性,还能优化程序的性能。

无论是处理简单的文本数据,还是进行复杂的数据分析,掌握Python的数据类型处理技巧都将使你在编程之路上如虎添翼。希望本文能帮助你更好地理解和运用Python中的数据类型,为你的Python编程实践提供参考。

相关文章:

深入理解Python常见数据类型处理

目录 概述数字类型 整数(int)浮点数(float)复数(complex) 字符串(str) 字符串基本操作字符串方法 列表(list) 列表基本操作列表方法列表推导式 元组&#xf…...

最佳实践:CI/CD交付模式下的运维展望丨IDCF

李洪锋 启迪万众数字技术(广州)有限公司 ,产品研发中心-系统运维部、研发效能(DevOps)工程师(中级)课程学员 一、DevOps现状 据云计算产业联盟《中国DevOps现状调查报告2023》显示,国内DevOps 落地成熟度…...

Flat Ads:开发者如何应对全球手游市场的洗牌与转型

2023年下半年至2024年上半年,中国手游的海外市场表现经历了显著变化,开发者要如何应对全球手游市场的洗牌与转型?本篇文章我们将结合相关行业白皮书的最新数据对中国手游出海表现进行分析与洞察。 一、中国手游海外市场表现 根据Sensor Tower《2024年海外手游市场洞察》最新…...

ai取名软件上哪找?一文揭秘5大ai取名生成器

在这个世界上,每一个新生命的到来都是一份奇迹,无论是一个新生儿的第一声啼哭,还是一只宠物的第一次摇尾巴,都充满了无限的希望和喜悦。 然而,给这个小生命起一个响亮、独特且富有意义的名字,往往让人煞费…...

ppt转换成pdf文件,这5个方法一键搞定!小白也能上手~

不管是工作上还是学习上,我们都会遇到转换文档格式的问题。比如常见的pdf转word,ppt转pdf,图片转pdf等。 很多软件都有自带的转换功能可以实现,但是需要保证转换后不乱码,且清晰度足够的方法还是少见的。本文整理了几个…...

中国每个软件创业者都是这个时代的“黑悟空”

作者 | 白鲸开源CEO 郭炜 我作为一个具有30游龄而20年都不碰游戏的游戏玩家,最近为了《黑神话:悟空》(简称,黑悟空),不但花重金更新了显卡,还第一次下载了Steam并绑定了支付,为的就是支持这个第…...

解决Qt多线程中fromRawData函数生成的QByteArray数据不一致问题

解决Qt多线程中fromRawData函数生成的QByteArray数据不一致问题 目录 🔔 问题背景📄 问题代码❓ 问题描述🩺 问题分析✔ 解决方案 🔔 问题背景 在开发一个使用Qt框架的多线程应用程序时,我们遇到了一个棘手的问题&…...

datax关于postsql数据增量迁移的问题

看官方文档是不支持的 数据源及同步方案_大数据开发治理平台 DataWorks(DataWorks)-阿里云帮助中心 (aliyun.com) 看了下源码有个postsqlwriter 看了下也就拼接sql 将 PostgresqlWriter中的不允许更新先注释了 让他过去先 然后看到 WriterUtil中的对应方法 getWriteTemplat…...

【Go】实现字符切片零拷贝开销转为字符串

package mainimport ("fmt""unsafe" )func main() {bytes : []byte("hello world")s : *(*string)(unsafe.Pointer(&bytes))fmt.Println(s)bytes[0] Hfmt.Println(s) }slice的底层结构是底层数组、len字段、cap字段。string的底层结构是底层…...

[sqlserver][sql]sqlserver查询执行过的历史sql

SQL是一个针对SQL Server数据库的查询执行过的历史 select * from (SELECT *FROM sys.dm_exec_query_stats QS CROSS APPLY sys.dm_exec_sql_text(QS.sql_handle) ST ) a where a.creation_time >2018-07-18 17:00:00 and charindex(delete from ckcdlist ,text)>0 an…...

python中n次方怎么表示

Python中的n次方用pow()方法来表示,pow()方法返回 xy(x的y次方)的值。 语法 以下是 math 模块 pow() 方法的语法: import math math.pow( x, y ) 内置的 pow() 方法 pow(x, y[, z]) 函数是计算x的y次方,如果z在存在&…...

Java数组怎么转List,Stream的基本方法使用教程

Stream流 Java 的 Stream 流操作是一种简洁而强大的处理集合数据的方式,允许对数据进行高效的操作,如过滤、映射、排序和聚合。Stream API 于 Java 8 引入,极大地简化了对集合(如 List、Set)等数据的处理。 一、创建 Stream 从集合创建: List<String> list = Ar…...

2024-07-12 - 基于 sealos 部署高可用 K8S 管理系统

摘要 Sealos 是一款以 Kubernetes 为内核的云操作系统发行版。它以云原生的方式&#xff0c;抛弃了传统的云计算架构&#xff0c;转向以 Kubernetes 为云内核的新架构&#xff0c;使企业能够像使用个人电脑一样简单地使用云。 操作实践 1、服务器规划 kubernetes集群大体上…...

Ps:首选项 - 单位与标尺

Ps菜单&#xff1a;编辑/首选项 Edit/Preferences 快捷键&#xff1a;Ctrl K Photoshop 首选项中的“单位与标尺” Units & Rulers选项卡允许用户根据工作需求定制 Photoshop 的测量单位和标尺显示方式。这对于保持工作的一致性和精确性&#xff0c;尤其是在跨设备或跨平台…...

DiskDigger(文件恢复工具) v2.0.3 中文授权版

DiskDigger中文版是一款实用文件恢复工具&#xff0c;它能从任何媒介中恢复误删除的文件。支持硬盘、USB 闪存盘、闪存卡(SD/CF/MMS)、CD、DVD 和软盘等。支持恢复任何格式的文件。DiskDigger 能彻底的扫描每个扇区来跟踪文件&#xff0c;从而最大限度恢复挽回文件信息。 软件…...

C/C++逆向:x96dbg(x64dbg/x86dbg)的使用

这篇文章主要来说一下x96dbg(x64/x86)的基本使用&#xff0c;这里还是使用上篇文章中的简单程序用来作为本篇文章的实例&#xff0c;因为上篇文章再生成程序时选用的解决方案平台为x86所以生成的程序则需要我们使用x32dbg来进行分析。 这边与IDA一样&#xff0c;我们可以将程序…...

超声波清洗机是智商税吗?专业博主分享四大必买超声波清洗机款式

有些人觉得超声波清洗机不过是个“智商税”&#xff0c;花几百块买个小盒子不值当&#xff0c;毕竟自己用手也能清洗。但这种看法过于片面。事实上&#xff0c;超声波清洗已经有几十年的历史&#xff0c;随着科技的发展&#xff0c;现代超声波清洗机不仅能够批量、自动清洁&…...

TIM输出比较

文章目录 前言一、TIM输出比较简介二、PWM简介2.1 PWM基本概念2.2 PWM参数2.3 PWM波形2.4 PWM基本结构2.5 PWM参数计算 三、舵机简介3.1 舵机的工作原理3.2 输入PWM信号的要求3.3 硬件电路 四、直流电机及驱动简介4.1 直流电机4.2 TB6612电机驱动芯片 前言 提示&#xff1a;本…...

JNPF 5.0升级钜惠,感恩回馈永远在路上

尊敬的JNPF用户们&#xff1a; 经过引迈团队数月的辛勤努力和不断的技术创新&#xff0c;JNPF快速开发平台迎来全新升级——5.0版本&#xff01;此次5.0版本的迭代革新&#xff0c;不仅代表着我们技术实力的进一步提升&#xff0c;是我们对用户需求的深度理解和积极回应。为了…...

三维平面电磁铁、交流电磁铁、显微镜磁场北京大学方案

根据用户北京大学需求设计制造方案如下 三维平面电磁铁产品规格 5MPS63-25型三维平面电磁铁&#xff0c;X、Y方向磁场由2对正交的磁极产生&#xff0c;Z轴由一组同轴线圈产生&#xff1b; 每轴对应的两个线圈正接产生均匀磁场&#xff0c;反接产生梯度磁场&#xff1b; …...

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...

内存分配函数malloc kmalloc vmalloc

内存分配函数malloc kmalloc vmalloc malloc实现步骤: 1)请求大小调整:首先,malloc 需要调整用户请求的大小,以适应内部数据结构(例如,可能需要存储额外的元数据)。通常,这包括对齐调整,确保分配的内存地址满足特定硬件要求(如对齐到8字节或16字节边界)。 2)空闲…...

Linux链表操作全解析

Linux C语言链表深度解析与实战技巧 一、链表基础概念与内核链表优势1.1 为什么使用链表&#xff1f;1.2 Linux 内核链表与用户态链表的区别 二、内核链表结构与宏解析常用宏/函数 三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势5.1 插入效率5.2 安全…...

golang循环变量捕获问题​​

在 Go 语言中&#xff0c;当在循环中启动协程&#xff08;goroutine&#xff09;时&#xff0c;如果在协程闭包中直接引用循环变量&#xff0c;可能会遇到一个常见的陷阱 - ​​循环变量捕获问题​​。让我详细解释一下&#xff1a; 问题背景 看这个代码片段&#xff1a; fo…...

中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试

作者&#xff1a;Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位&#xff1a;中南大学地球科学与信息物理学院论文标题&#xff1a;BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接&#xff1a;https://arxiv.…...

线程同步:确保多线程程序的安全与高效!

全文目录&#xff1a; 开篇语前序前言第一部分&#xff1a;线程同步的概念与问题1.1 线程同步的概念1.2 线程同步的问题1.3 线程同步的解决方案 第二部分&#xff1a;synchronized关键字的使用2.1 使用 synchronized修饰方法2.2 使用 synchronized修饰代码块 第三部分&#xff…...

定时器任务——若依源码分析

分析util包下面的工具类schedule utils&#xff1a; ScheduleUtils 是若依中用于与 Quartz 框架交互的工具类&#xff0c;封装了定时任务的 创建、更新、暂停、删除等核心逻辑。 createScheduleJob createScheduleJob 用于将任务注册到 Quartz&#xff0c;先构建任务的 JobD…...

2025盘古石杯决赛【手机取证】

前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来&#xff0c;实在找不到&#xff0c;希望有大佬教一下我。 还有就会议时间&#xff0c;我感觉不是图片时间&#xff0c;因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...

鱼香ros docker配置镜像报错:https://registry-1.docker.io/v2/

使用鱼香ros一件安装docker时的https://registry-1.docker.io/v2/问题 一键安装指令 wget http://fishros.com/install -O fishros && . fishros出现问题&#xff1a;docker pull 失败 网络不同&#xff0c;需要使用镜像源 按照如下步骤操作 sudo vi /etc/docker/dae…...

CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云

目前已有本地上传、阿里云OSS上传、腾讯云COS上传、七牛云上传扩展 扩展入口文件 文件目录 crmeb\services\upload\Upload.php namespace crmeb\services\upload;use crmeb\basic\BaseManager; use think\facade\Config;/*** Class Upload* package crmeb\services\upload* …...