百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

如何在 Python 中反转字符串? python字符反转函数

bigegpt 2024-10-10 04:34 51 浏览

在 Python 中,字符串是 Unicode 字符的序列,尽管 Python 支持许多用于字符串操作的函数,但它没有明确设计用于反转字符串的内置函数或方法。

>>> 'Linuxize'.reverse()
Traceback (most recent call last):
File "<input>", line 1, in <module>
AttributeError: 'str' object has no attribute 'reverse'

字符串反转不是编程中的常见操作,通常用于编码面试。

本文介绍了在 Python 中反转字符串的几种不同方法。

使用切片

了解 Python 中的索引如何工作对于执行字符串切片操作至关重要,通常,索引号用于访问字符串中的特定字符。

有两种类型的索引:正负索引

您可以n通过 的正索引号2或通过 的负索引号来访问字符-6:

>>> print('Linuxize'[2])
n
>>> print('Linuxize'[-6])
n

我们可以通过切片技术从字符串中调出一系列字符,切片是从给定字符串中提取子字符串序列的操作。

切片语法:

string[start:stop:step]
  • 第一个参数指定提取开始的索引,当使用负索引时,它表示距字符串末尾的偏移量。如果省略此参数,则切片从索引 0 开始。
  • 第二个参数指定结束提取的索引,结果不包括该stop元素。当使用负索引时,它表示距字符串末尾的偏移量。如果此参数被省略或大于字符串的长度,则切片到字符串的末尾。
  • 第三个参数是可选的,指定切片的步骤,不使用step参数时,默认为 1。使用负值时,切片以相反的顺序获取元素。

对字符串进行切片的结果是一个包含提取元素的新字符串,并且原始字符串没有被修改。

要使用切片反转字符串,请省略startandstop参数并使用负步长增量-1.

的负步长增量-1表示切片从最后一个元素开始,到第一个元素结束,产生一个反转的字符串。

>>> print('Linuxize'[::-1])
ezixuniL

您还可以定义自定义函数并使用它来反转字符串:

def rev_str_thru_slicing(str_):
    return str_[::-1]

INPUT_STRING = "Linuxize"

if __name__ == '__main__':
    print("INPUT STRING -", INPUT_STRING)
    print("REVERSED STRING -", rev_str_thru_slicing(INPUT_STRING))
Input String - Linuxize
Reversed String using Slicing - ezixuniL

使用reversed()功能

内置reserved()函数以相反的顺序处理字符串项并返回一个反向迭代器。

在下面的示例中,使用运算符将反向迭代器的元素添加到空字符串中join():

def rev_str_thru_join_revd(STR):
    return "".join(reversed(STR)) 

INPUT_STRING = "Linuxize" 

if __name__ == '__main__':

    print("INPUT STRING -", INPUT_STRING)
    print("RESERVED STRING THROUGH JOIN & REVERSED", rev_str_thru_join_revd(INPUT_STRING))
Input String - Linuxize
Reserved String Through Join & Reserved Methods - ezixuniL

使用列表reverse()

要使用list 方法反转字符串reverse(),首先需要使用list构造函数将字符串转换为列表,然后使用该方法将列表项反转到位reverse(),最后使用该方法将列表项连接成一个字符串join()。

这是一个例子:

def rev_str_thru_list_reverse(STR):
    lst = list(STR)
    lst.reverse()
    return(''.join(lst))
 
INPUT_STRING = "Linuxize"
 
if __name__ == '__main__':
    print("Input String -", INPUT_STRING)

print("Reserved String Through List", rev_str_thru_list_reverse(INPUT_STRING))
Input String - Linuxize
Reserved String Through List Reverse Method - ezixuniL

使用递归函数

在 Python 中,递归函数是一个在满足某个条件之前调用自身的函数。

在下面的代码片段中,rev_str_thru_recursion函数调用自身,直到字符串长度大于零。每次调用时,都会对字符串进行切片,只留下第一个字符。稍后,它与切片字符连接。

def rev_str_thru_recursion(STR):
    if len(STR) == 0:
         return STR
    else:
        return rev_str_thru_recursion(STR[1:]) + STR[0]

INPUT_STRING = "Linuxize"

if __name__ == '__main__':
    print("INPUT STRING -", INPUT_STRING)

print("RESERVED STRING THROUGH RECURSION", rev_str_thru_recursion(INPUT_STRING))

对比分析

在本节中,我们将对这四种定义的方法进行简单比较,以确定它们的效率。我们将使用名为“timeit”的 Python 模块来分析性能。它提供了执行代码片段所花费的时间。“timeit”模块的“repeat”选项有助于重复代码执行一百万次。我们可以将输出理解为执行代码片段一百万次所花费的平均时间。

上表显示,Slicing 方法比 List Reverse 方法快 7 倍,比 Join & Reserved 方法快 7.5 倍,比递归方法快 83 倍。所以切片是反转字符串的最快和最好的方法。

以上结果是在相同环境下讨论的字符串反转方法的对比分析。在不同的计算环境中,数字可能会有所不同,但比例可能会保持不变。

if __name__ == "__main__":

    ## Performance Calculation

    import timeit
    from statistics import mean

    s = INPUT_STRING * 10
    repeatCount = 100

    SLICING_PERF = timeit.repeat(lambda: rev_str_thru_slicing(s), repeat=repeatCount)
    print(min(SLICING_PERF), mean(SLICING_PERF), max(SLICING_PERF), SLICING_PERF)

    J_R_PERF = timeit.repeat(lambda: rev_str_thru_join_revd(s), repeat=repeatCount)
    print(min(J_R_PERF), mean(J_R_PERF), max(J_R_PERF), J_R_PERF)

    LIST_PERF = timeit.repeat(lambda: rev_str_thru_list_reverse(s), repeat=repeatCount)
    print(min(LIST_PERF), mean(LIST_PERF), max(LIST_PERF), LIST_PERF)

    RECUR_PERF = timeit.repeat(lambda: rev_str_thru_recursion(s), repeat=repeatCount)
    print(min(RECUR_PERF), mean(RECUR_PERF), max(RECUR_PERF), RECUR_PERF)

结论

Python没有任何内置函数来反转字符串,但我们可以使用其他方法来反转字符串。回归测试分析表明,切片方法是反转字符串最快的方法。

相关推荐

Go语言泛型-泛型约束与实践(go1.7泛型)

来源:械说在Go语言中,Go泛型-泛型约束与实践部分主要探讨如何定义和使用泛型约束(Constraints),以及如何在实际开发中利用泛型进行更灵活的编程。以下是详细内容:一、什么是泛型约束?**泛型...

golang总结(golang实战教程)

基础部分Go语言有哪些优势?1简单易学:语法简洁,减少了代码的冗余。高效并发:内置强大的goroutine和channel,使并发编程更加高效且易于管理。内存管理:拥有自动垃圾回收机制,减少内...

Go 官宣:新版 Protobuf API(go pro版本)

原文作者:JoeTsai,DamienNeil和HerbieOng原文链接:https://blog.golang.org/a-new-go-api-for-protocol-buffer...

Golang开发的一些注意事项(一)(golang入门项目)

1.channel关闭后读的问题当channel关闭之后再去读取它,虽然不会引发panic,但会直接得到零值,而且ok的值为false。packagemainimport"...

golang 托盘菜单应用及打开系统默认浏览器

之前看到一个应用,用go语言编写,说是某某程序的windows图形化客户端,体验一下发现只是一个托盘,然后托盘菜单的控制面板功能直接打开本地浏览器访问程序启动的webserver网页完成gui相关功...

golang标准库每日一库之 io/ioutil

一、核心函数概览函数作用描述替代方案(Go1.16+)ioutil.ReadFile(filename)一次性读取整个文件内容(返回[]byte)os.ReadFileioutil.WriteFi...

文件类型更改器——GoLang 中的 CLI 工具

我是如何为一项琐碎的工作任务创建一个简单的工具的,你也可以上周我开始玩GoLang,它是一种由Google制作的类C编译语言,非常轻量和快速,事实上它经常在Techempower的基准测...

Go (Golang) 中的 Channels 简介(golang channel长度和容量)

这篇文章重点介绍Channels(通道)在Go中的工作方式,以及如何在代码中使用它们。在Go中,Channels是一种编程结构,它允许我们在代码的不同部分之间移动数据,通常来自不同的goro...

Golang引入泛型:Go将Interface「」替换为“Any”

现在Go将拥有泛型:Go将Interface{}替换为“Any”,这是一个类型别名:typeany=interface{}这会引入了泛型作好准备,实际上,带有泛型的Go1.18Beta...

一文带你看懂Golang最新特性(golang2.0特性)

作者:腾讯PCG代码委员会经过十余年的迭代,Go语言逐渐成为云计算时代主流的编程语言。下到云计算基础设施,上到微服务,越来越多的流行产品使用Go语言编写。可见其影响力已经非常强大。一、Go语言发展历史...

Go 每日一库之 java 转 go 遇到 Apollo?让 agollo 来平滑迁移

以下文章来源于GoOfficialBlog,作者GoOfficialBlogIntroductionagollo是Apollo的Golang客户端Apollo(阿波罗)是携程框架部门研...

Golang使用grpc详解(golang gcc)

gRPC是Google开源的一种高性能、跨语言的远程过程调用(RPC)框架,它使用ProtocolBuffers作为序列化工具,支持多种编程语言,如C++,Java,Python,Go等。gR...

Etcd服务注册与发现封装实现--golang

服务注册register.gopackageregisterimport("fmt""time"etcd3"github.com/cor...

Golang:将日志以Json格式输出到Kafka

在上一篇文章中我实现了一个支持Debug、Info、Error等多个级别的日志库,并将日志写到了磁盘文件中,代码比较简单,适合练手。有兴趣的可以通过这个链接前往:https://github.com/...

如何从 PHP 过渡到 Golang?(php转golang)

我是PHP开发者,转Go两个月了吧,记录一下使用Golang怎么一步步开发新项目。本着有坑填坑,有错改错的宗旨,从零开始,开始学习。因为我司没有专门的Golang大牛,所以我也只能一步步自己去...