Python str join方法:拼接字符串「建议收藏」

Python str join方法:拼接字符串「建议收藏」Python字符串方法join()介绍、使用和注意事项。

大家好,又见面了,我是你们的朋友全栈君。

目录

描述

语法

举例

1. 元素序列是列表

2. 元素序列是元组

3. 元素序列是集合

4. 元素序列是字典

5. 元素序列是字符串

注意事项

1. 要连接的字符串序列(参数)必须是字符串

2. 字符串连接符可省略

3. 当可迭代序列是集合时,拼接结果是无序的

4. 当可迭代序列是字典时,拼接结果是键的拼接

join方法和‘+’性能比较


描述

str.join()方法是Python的字符串方法,用于将序列中的元素以指定的字符串连接成一个新的字符串。

语法

string.join(sequence)
名称 说明 备注
string 字符串连接符 可省略
sequence 要连接的元素序列 不可省略的参数,序列的元素是字符串

举例

1. 元素序列是列表

>>> a = '!@'.join(['Fusion', 'Sphere', 'Cloud'])
>>> a
'Fusion!@Sphere!@Cloud'

2. 元素序列是元组

>>> " ".join(('China', 'Japan', 'USA', 'UK'))
'China Japan USA UK'

3. 元素序列是集合

>>> ''.join({'C', 'h', 'i', 'n', 'a'})
'ahCni'

可以看出,输出的字符顺序与集合中元素的顺序不是保持一致的。

4. 元素序列是字典

>>> ' ~ '.join({'Asia':'China', 'Europe':'UK'})
'Asia ~ Europe'

可以看出,如果序列是字典,拼接的字符是字典的键。

5. 元素序列是字符串

当元素序列仅仅是字符串时,join函数会将字符串中的每一个单个字符抽取出来,与连接符组合。

>>> ', '.join('happy')
'h, a, p, p, y'

注意事项

1. 要连接的字符串序列(参数)必须是字符串

join函数的参数应该是全部由字符串构成的可迭代对象。当可迭代对象不全是由字符串构成的时,Python会报错TypeError。

例如,参数是一个由字符串和整数构成的列表时:

>>> ' * '.join(['1', 2])
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: sequence item 1: expected str instance, int found

2. 字符串连接符可省略

字符串连接符可以省略(空字符串)。当字符串连接符为空时,序列中的所有字符串都将连接成一个字符串。

>>> ''.join(['1', '2', '3', '4', '5'])
'12345'

3. 当可迭代序列是集合时,拼接结果是无序的

如果可迭代序列参数是集合,join的返回结果不一定是元素在集合中的顺序,而是打乱的:

>>> ' -- '.join({'a', 'b', 'c'})
'b -- c -- a'

4. 当可迭代序列是字典时,拼接结果是键的拼接

如果可迭代序列参数是字典,join的返回结果是字典中键的拼接结果,而不是键值对的拼接结果。

可以用values函数来拼接值的结果。

>>> test_dict = {'A':'a', 'B':'b', 'C':'c'}
>>> "".join(test_dict)
'ABC'
>>> "".join(test_dict.values())
'abc'

join方法和‘+’性能比较

join()方法和 + 号都可以拼接字符串,但是性能却差异很大。

先来看下面的例子:

下面的例子是将列表str_list中的每个元素分别通过“+”和join方法拼接并重复执行1000次,并比较时间差异。

import time

def spend(func):
    def wapper(*args, **kwargs):
        start = time.time()
        # 为了更好的体验性能差异,重复执行1000遍
        for i in range(1000):
            func(*args, **kwargs)
        end = time.time()
        spend_time = end - start
        print("Spend time: %.6f" % spend_time)
        return
    return wapper

# 通过+号拼接字符串
@ spend
def use_add_opertor(str_list):
    result = ""
    for data in str_list:
        result = result + data

    return


# 通过str.join()方法拼接字符串
@ spend
def use_join_method(str_list):
    result = "".join(str_list)
    return


if __name__ == "__main__":
    # 为了充分体现性能差异,我们把要拼接的字符串列表多写一点
    str_list = ["Python", "OpenStack", "data structure", "arithmetic", "Flask", "MySql",
                "concurrence", "PySpider", "HTML", "CSS", "C", "C++"]
    print("1. Use add operator..")
    use_add_opertor(str_list)

    print("-" * 30)

    print("2. Use str.join() method..")
    use_join_method(str_list)

运行结果如下:

1. Use add operator..
Spend time: 0.001079
------------------------------
2. Use str.join() method..
Spend time: 0.000360

可以看出,在我这台机器上,使用+号拼接字符串比使用str.join()方法拼接字符串消耗时常多了将近2倍。

那么为什么使用join()方法时间会更快一些呢?

因为在Python中字符串是不可变对象,修改字符串就得将原字符串中的值复制,开辟一块新的内存,加上修改的内容后写入到新内存中,以达到“修改”字符串的效果。在使用“+”拼接字符串时,正是使用了重复性的复制、申请新内存、写入值到新内存的工作一遍遍的将字符串的值修改。而使用join()方法拼接字符串时,会先计算总共需要申请多少内存,然后一次性申请所需内存并将字符串复制过去。这样便省去了重复性的内存申请和写入,节省了时间消耗。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/130931.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Python websocket_php需要编译吗

    Python websocket_php需要编译吗这里很坑爹………地址换了….网上到处都是旧的github地址….更郁闷的是旧地址的代码在centos等各个linux都能编译通过,但是到了mac就郁闷了,各种报错…..坑爹来的然后很多人说hs没在维护了,那是因为他们看到的是旧的git代码地址….囧…..搞死我了,我还真以为他不更新了,看到git项目,3年没更新了,心都凉了……各种找错误各种…

    2022年8月24日
    6
  • JDK环境变量配置

    JDK环境变量配置一.下载JDK安装包并安装JDK下载链接二.JDK环境变量配置1.右击我的电脑->属性->高级系统设置->环境变量2.在系统变量区域新建一个JAVA_HOME,变量值为上一步JDK安装目录3.编辑PATH变量,新增环境变量%JAVA_HOME%\bin4.新增系统变量CLASSPATH,变量值输入.;%JAVA_HOME%\lib;%JAVA_HOME%\lib\tools.jar(注意最前面有一点)5.连续点击确定保存之后,打开命令提示符窗口,输入“java-v

    2022年7月17日
    18
  • navicat 1146错误「建议收藏」

    navicat 1146错误「建议收藏」打开新安装的navicat后,有个test_3306的mysql连接,里面有写默认的mysql、information_schema、sys、performance_schema数据库,我以为这是没用的就删除了,之后建立自己的mysql连接后,打开连接报错1146-Table’historyhistoryperformance_schema.session_status’doesn’texist。查阅资料后了解mysql、information_schema、sys、performance_s

    2022年6月7日
    184
  • jQuery 如何得到 scrollHeight 的值

    jQuery 如何得到 scrollHeight 的值之前为了得到dom的scrollHeight的值,一直写法是这样的: [b]$(‘#box’)[0].scrollHeight[/b]今天我知道了另外一个方法: [b]$(‘#box’).prop(‘scrollHeight’)[/b]注意: [b]$(‘#box’).arrt(‘scrollHeight’);[/b]这个写法是undefined值[i

    2022年7月24日
    14
  • oracle ORA-00918 未明确定义列「建议收藏」

    oracle ORA-00918 未明确定义列「建议收藏」 出现这种错误,一般是列名重复导致的,如下: createtabletestchar(v_datevarchar2(20),d_datedate)insertintotestcharselect’2018-07-20′,date’2018-07-20’fromdual;#这时候有两个字段都是vv,那么查询时,就会区分不出来这两列,oracl…

    2022年10月4日
    5
  • Oracle SEQUENCE 详细说明[通俗易懂]

    Oracle SEQUENCE 详细说明[通俗易懂]ORACLE SEQUENCE  ORACLE没有自增数据类型,如需生成业务无关的主键列或惟一约束列,可以用sequence序列实现。CREATESEQUENCE语句及参数介绍:创建序列:需要有CREATESEQUENCE或者CREATEANYSEQUENCE权限, CREATESEQUENCE[schema.]sequence  [{IN

    2022年10月18日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号