zoukankan      html  css  js  c++  java
  • Python中的join()函数split()函数

    函数:string.join()

    Python中有join()和os.path.join()两个函数,具体作用如下:
        join():    连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串
        os.path.join():  将多个路径组合后返回

    一、函数说明
    1、join()函数

    语法:  'sep'.join(seq)

    参数说明
    sep:分隔符。可以为空
    seq:要连接的元素序列、字符串、元组、字典
    上面的语法即:以sep作为分隔符,将seq所有的元素合并成一个新的字符串

    返回值:返回一个以分隔符sep连接各个元素后生成的字符串

    2、os.path.join()函数

    语法:  os.path.join(path1[,path2[,......]])

    返回值:将多个路径组合后返回

    注:第一个绝对路径之前的参数将被忽略

    注:容器对象内的元素须为字符类型

    #对序列进行操作(分别使用' '与':'作为分隔符)
    >>> seq1 = ['hello','good','boy','doiido']
    >>> print ' '.join(seq1)
    hello good boy doiido
    >>> print ':'.join(seq1)
    hello:good:boy:doiido
     
    #对字符串进行操作
    >>> seq2 = "hello good boy doiido"
    >>> print ':'.join(seq2)
    h:e:l:l:o: :g:o:o:d: :b:o:y: :d:o:i:i:d:o
     
    #对元组进行操作
    >>> seq3 = ('hello','good','boy','doiido')
    >>> print ':'.join(seq3)
    hello:good:boy:doiido
     
    #对字典进行操作:   dict是以Key值作连接, #dict 的无序性,使元素随机连接。set 同理
    >>> seq4 = {'hello':1,'good':2,'boy':3,'doiido':4}
    >>> print ':'.join(seq4)
    boy:good:doiido:hello
     
    #合并目录
    >>> import os
    >>> os.path.join('hello','goodboy','doiido')
    'hellogoodboydoiido'   #windows platform auto add between each string
    'hello/goodboy/doiido'      #linux platform auto add / between each string

    ----------------------------------------------------------------------------------------------

    函数:split()

    Python中有split()和os.path.split()两个函数,具体作用如下:
    split():拆分字符串。通过指定分隔符对字符串进行切片,并返回分割后的字符串列表(list)
    os.path.split():按照路径将文件名和路径分割开

    一、函数说明
    1、split()函数

    语法:str.split(str="",num=string.count(str))[n]

    参数说明:
    str:   表示为分隔符,默认为空格,但是不能为空('')。若字符串中没有分隔符,则把整个字符串作为列表的一个元素
    num:表示分割次数。如果存在参数num,则仅分隔成 num+1 个子字符串,并且每一个子字符串可以赋给新的变量
    [n]:   表示选取第n个分片

    注意:当使用空格作为分隔符时,对于中间为空的项会自动忽略

    2、os.path.split()函数
    语法:os.path.split('PATH')

    参数说明:

      1. PATH指一个文件的全路径作为参数:
      2. 如果给出的是一个目录和文件名,则输出路径和文件名
      3. 如果给出的是一个目录名,则输出路径和为空文件名
    >>> u = "www.doiido.com.cn"
      
    #使用默认分隔符
    >>> print u.split()
    ['www.doiido.com.cn']
      
    #以"."为分隔符
    >>> print u.split('.')
    ['www', 'doiido', 'com', 'cn']
      
    #分割0次
    >>> print u.split('.',0)
    ['www.doiido.com.cn']
      
    #分割一次
    >>> print u.split('.',1)
    ['www', 'doiido.com.cn']
      
    #分割两次
    >>> print u.split('.',2)
    ['www', 'doiido', 'com.cn']
      
    #分割两次,并取序列为1的项
    >>> print u.split('.',2)[1]
    doiido
      
    #分割最多次(实际与不加num参数相同)
    >>> print u.split('.',-1)
    ['www', 'doiido', 'com', 'cn']
      
    #分割两次,并把分割后的三个部分保存到三个文件
    >>> u1,u2,u3 = u.split('.',2)
    >>> print u1
    www
    >>> print u2
    doiido
    >>> print u3
    com.cn
    ----------------------------------------------------------------------------------------
    去掉换行符
    >>> c = '''say
    hello
    baby'''
      
    >>> print c
    say
    hello
    baby
      
    >>> print c.split(' ')
    ['say', 'hello', 'baby']
     
    分离文件名和路径
    >>> import os
    >>> print os.path.split('/dodo/soft/python/')
    ('/dodo/soft/python', '')
    >>> print os.path.split('/dodo/soft/python')
    ('/dodo/soft', 'python')
     
    一个超级好的例子
    >>> str="hello boy<[www.doiido.com]>byebye"
      
    >>> print str.split("[")[1].split("]")[0]
    www.doiido.com
      
    >>> print str.split("[")[1].split("]")[0].split(".")
    ['www', 'doiido', 'com']
     
     
     
     
     
    import os

    def currentpath(file):
        try:
            filepath = os.path.abspath(
                os.path.join(
                    os.path.join(os.path.dirname(file), os.pardir), os.pardir, 'elements/' + 'IOS' + '_elements'))
            return filepath
        except Exception,msg:
            print msg


    print __file__  #allen.py

    s1 = os.path.abspath(__file__)
    print s1         # C:pythonnallen.py

    s2 = os.path.dirname(s1)
    print s2         # C:pythonn

    print os.pardir   # ..

    print currentpath(__file__)  # C:elementsIOS_elements

    print os.path.join('hello','good','boy')  # hellogoodoy
  • 相关阅读:
    leetcode1137. 第 N 个泰波那契数 吴丹阳
    改变网络接口的速度和协商方式的工具miitool 和ethtool (v0.1b)
    复杂组网模式
    wrk性能测试工具使用
    miitool 和ethtool工具介绍
    个人常用工具及命令脚本:
    python实现注册登录flask框架web开发实践
    记一次 RR 与 RC 死锁问题排查
    WGCLOUD可以作为链路监测工具吗
    WGCLOUD的server启动不了问题的终极解决办法
  • 原文地址:https://www.cnblogs.com/kex1n/p/5991542.html
Copyright © 2011-2022 走看看