生成器函数, re中函数的使用,模拟range的功能

简介: 1、生成1-10使用next(generator)方法获取1-102、使用for循环获取

一、定义一个生成器函数,

1、生成1-10使用next(generator)方法获取1-10

2、使用for循环获取

def data():
    for i in range(1,11):
        yield i
data =data()
print(next(data))
for i in data:
    print(i)
1
2
3
4
5
6
7
8
9

二、模拟range的功能,自己建立一个range:MyRange

class MyIterator:
    def __init__(self, start=0, stop=0, step=0):
        self.start = start
        self.stop = stop
        self.step = step
    def __iter__(self):
        return self
    def __next__(self):
        data = self.start
        if self.start < self.stop:
            self.start += self.step
            return data
        else:
            raise StopIteration
for i in MyIterator(1, 10, 3):
    print(i)
 1
 4
 7

三、re中函数的使用

match

fullmatch

search

findall

finditer

split

sub

subn

complie

str_var = 'abc'
data = 'aabcbcabca'
obj_match = re.match(str_var, data)
print(obj_match)
# fullmatch
obj_full = re.fullmatch(str_var, data)
print(obj_full)
# search
obj_sea = re.search(str_var, data)
print(obj_sea)
# findall
obj_fin = re.findall(str_var, data)
print(obj_fin)
# finditer
obj_findier = re.finditer(str_var, data)
print(list(obj_findier))
# split
str_data = "西安培华,西安鸥鹏,西京"
pattern = ","
result = re.split(pattern, str_data, 1)
print(result)
# sub
str_data = "西安培华,西安鸥鹏,西京"
pattern = ","
result = re.sub(",", "|", str_data, 1)
print(result)
# subn
result = re.subn(",", "|", str_data)
print(result)
# complie
# 获取编译对象的函数
pattern = "abc"
str_data = "abcabcabc"
compile_obj = re.compile(pattern)
print(compile_obj)
print(compile_obj.match(str_data))
print(compile_obj.search(str_data))
print(compile_obj.findall(str_data))
# 输出
None
None
<re.Match object; span=(1, 4), match='abc'>
['abc', 'abc']
[<re.Match object; span=(1, 4), match='abc'>, <re.Match object; span=(6, 9), match='abc'>]
['西安培华', '西安鸥鹏,西京']
西安培华|西安鸥鹏,西京
('西安培华|西安鸥鹏|西京', 2)
re.compile('abc')
<re.Match object; span=(0, 3), match='abc'>
<re.Match object; span=(0, 3), match='abc'>
['abc', 'abc', 'abc']
相关文章
|
人工智能 API 语音技术
[译][AI OpenAI-doc] 文字转语音
学习如何将文字转换为栩栩如生的口头语音。音频 API 提供基于我们的 TTS(文本到语音)模型的语音端点,支持实时音频流传输。
mqc
|
缓存 安全 Java
测试之道--阿里巴巴八年测试专家倾情奉献
我从事测试工作将近八年了,从起初的不懂测试,怀疑测试,到相信测试,再到坚定测试,其中经历的辛酸、煎熬无法言表。在从事测试工作的这八年里,有人质疑,也有人追捧,唇枪舌剑,没完没了,貌似测试永远都是个站在舆论风口浪尖的角色。
mqc
8825 0
|
Ubuntu 网络安全 数据安全/隐私保护
如何在 Ubuntu 上创建一个 SSH CA 以验证主机和客户端
如何在 Ubuntu 上创建一个 SSH CA 以验证主机和客户端
233 0
|
Java Linux Shell
centos7内网离线安装face_recognition、python、pip、CMake、dlib,离线升级gcc/切换gcc,文末有face_recognition的docker版本
公司项目需要人脸识别,本来app自带人脸识别,结果api支持的设备试了一圈就一个同事的华为Mate40Pro可以,所以使用无望。接着找了一下免费的java离线人脸识别sdk,发现虹软的确实简单好用,一会就在linux上弄好并测试通过了,然而在准备集成进去开写代码时,不小心看到了一眼首次激活需联网,后续方可离线使用,好吧,我们内网机器首次都不可能的,接着看了下离线激活方法,首先需要企业认证,这一步我们肯定没法做的,毕竟不是之前的小公司了,营业执照啥的随便给我肯定不行,直接放弃了。后来在同事推荐下看了下face_recognition这个项目,之前基本没用过python,于是有了漫长的踩坑之旅。
1135 1
|
SQL Oracle 关系型数据库
MySql基础一之【了解MySql与DBeaver操作MySql】
MySql基础一之【了解MySql与DBeaver操作MySql】
351 0
|
测试技术 Java Spring
Spring 框架中的测试之道:揭秘单元测试与集成测试的双重保障,你的应用真的安全了吗?
【8月更文挑战第31天】本文以问答形式深入探讨了Spring框架中的测试策略,包括单元测试与集成测试的有效编写方法,及其对提升代码质量和可靠性的重要性。通过具体示例,展示了如何使用`@MockBean`、`@SpringBootTest`等注解来进行服务和控制器的测试,同时介绍了Spring Boot提供的测试工具,如`@DataJpaTest`,以简化数据库测试流程。合理运用这些测试策略和工具,将助力开发者构建更为稳健的软件系统。
166 0
|
域名解析 弹性计算 开发者
期待已久,重磅回归,阿里云推出全新《高效构建企业门户网站方案》,你想了解的,这一篇就足够了。
期待已久,重磅回归,《高效构建企业门户网站方案》,你想了解的,这一篇就足够了。
24603 3
|
消息中间件 Java 开发者
如何避免RabbitMQ消息丢失?
本文探讨了RabbitMQ中如何避免消息丢失的问题。在默认情况下,RabbitMQ并不保证消息的持久性,但提供了多种机制来确保消息的可靠传输与处理。文章分析了消息可能丢失的关键环节,并介绍了相应的保证机制:发布者确认交换机已接收消息、确认队列接收消息、队列及消息的持久化,以及消费者成功处理消息后的确认。通过Java代码示例展示了如何在实际应用中实现这些机制。最终,确保了消息在从生产到消费的整个流程中的可靠性。
271 0
|
分布式计算 大数据 专有云
MaxCompute产品使用合集之需要将多个字段concat起来,有时候遇到null值,该怎么做
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
SQL 关系型数据库 MySQL
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version
641 0
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version