举例详解Python中的split()函数的使用方法

http://www.jb51.net/article/63592.htm

函数: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. 如果给出的是一个目录名,则输出路径和为空文件名


二、实例
1、常用实例
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
>>> 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


2、去掉换行符
 

?
1
2
3
4
5
6
7
8
9
10
11
>>> c = '''say
hello
baby'''
  
>>> print c
say
hello
baby
  
>>> print c.split( '\n' )
[ 'say' , 'hello' , 'baby' ]

3、分离文件名和路径
 

?
1
2
3
4
5
>>> import os
>>> print os.path.split( '/dodo/soft/python/' )
( '/dodo/soft/python' , '')
>>> print os.path.split( '/dodo/soft/python' )
( '/dodo/soft' , 'python' )

4、一个超级好的例子
 

?
1
2
3
4
5
6
7
>>> 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' ]

如对本文有疑问,请提交到交流社区,广大热心网友会为你解答!! 点击进入社区




<think>好的,用户想了解Python中的oct函数使用方法和示例。首先,我需要回顾一下oct函数的基本功能。根据之前的引用,oct函数用于将整数转换为八进制字符串。例如,oct(10)应该返回'0o12'。 接下来,用户可能需要具体的示例来理解不同情况下的使用。比如,处理不同进制的输入,如十进制、二进制、十六进制,如何正确转换为八进制。这里需要注意,oct函数只接受整数类型的参数,如果输入其他类型,比如字符串,会抛出TypeError,需要处理异常情况。 用户可能还想知道oct函数与其他函数的结合使用,比如如何将返回的八进制字符串进行处理,比如去掉前缀'0o',或者分割字符串。根据引用[2],可以结合字符串方法split()、replace()来实现这些操作。例如,使用replace('0o', '')可以得到不带前缀的八进制数字。 另外,引用[3]提到oct函数的实际应用场景,比如处理文件权限、网络编程中的掩码设置等。这部分需要具体举例说明,让用户了解在实际编程中如何应用oct函数。 还需要注意oct函数的注意事项,比如处理负数时,返回的是带有负号的八进制字符串,如oct(-10)返回'-0o12'。对于非整数输入,如浮点数,oct函数会报错,这时需要先转换为整数类型。 用户之前的问题涉及对象函数使用,虽然oct函数属于内置函数,但可能需要说明它与对象方法的不同,确保用户不会混淆内置函数和类的方法。 最后,整理示例代码,覆盖基本使用、不同进制转换、异常处理、字符串处理以及实际应用案例。同时,确保回答结构清晰,分点说明,便于用户理解。</think>### Python中`oct()`函数详解与实战指南 --- #### 一、函数定义与基本用法 `oct()`是Python的内置函数,**用于将整数转换为八进制(Octal)字符串**,返回格式为`0o`开头的字符串。其语法为: $$ \text{oct}(x) $$ 其中`x`必须为整数类型(包括负整数)。 **基础示例**: ```python print(oct(10)) # 输出: '0o12' print(oct(0b111)) # 输出: '0o7'(二进制111→十进制7→八进制7) print(oct(0x1F)) # 输出: '0o37'(十六进制1F→十进制31→八进制37) ``` --- #### 二、不同输入类型的处理 | 输入类型 | 处理方式 | 示例代码及输出 | |------------------|-------------------------------|-------------------------------| | **正整数** | 直接转换为八进制字符串 | `oct(15) → '0o17'` | | **负整数** | 添加负号 | `oct(-8) → '-0o10'` | | **其他进制数** | 先转为十进制再转换 | `oct(0b1010) → '0o12'` | | **浮点数** | 抛出`TypeError`异常 | `oct(3.14) → 报错` | | **非整数类型** | 必须显式转换为整数 | `oct(int('20')) → '0o24'` | --- #### 三、常见应用场景 1. **文件权限设置** 在Linux系统编程中,文件权限常以八进制表示: ```python mode = 0o755 # 八进制写法 print(oct(mode).replace('0o', '')) # 输出: '755' ``` 2. **网络掩码处理** 处理IP地址的子网掩码时: ```python mask = 0b11111111_11111111_11111111_00000000 print(oct(mask)[2:]) # 输出: '37777777400'(IPv4掩码255.255.255.0的八进制表示) ``` 3. **数字系统转换工具** 结合其他进制转换函数: ```python num = 30 print(f"十进制: {num} → 八进制: {oct(num)} → 十六进制: {hex(num)}") ``` --- #### 四、高级技巧与注意事项 1. **字符串处理** 使用字符串方法优化输出(引用[^2]): ```python oct_str = oct(100).replace('0o', '').zfill(4) # 去前缀并填充为4位 print(oct_str) # 输出: '0144' ``` 2. **异常处理** 处理非整数输入的异常: ```python def safe_oct(x): try: return oct(int(x)) except ValueError: return "输入必须为整数" print(safe_oct('abc')) # 输出: '输入必须为整数' ``` 3. **自定义进制转换** 若需去除八进制前缀,可自定义函数: ```python def custom_oct(x): return oct(x)[2:] if x >=0 else '-' + oct(abs(x))[2:] print(custom_oct(64)) # 输出: '100' ``` --- #### 五、与其他函数的结合使用 | 组合场景 | 代码示例 | 输出结果 | |-----------------------|---------------------------------------------|---------------------| | **与`int()`配合** | `int(oct(31), 8)` | `31` | | **格式化字符串** | `f"{31:o}"` | `'37'` | | **处理字节数据** | `bytes.fromhex(hex(int(oct(255),8))[2:])` | `b'\xff'` | --- #### 六、常见错误解决方案 | 错误场景 | 解决方案 | |-------------------------|---------------------------------------------| | 浮点数输入报错 | 使用`int()`强制转换:`oct(int(3.0))` | | 非数字类型输入 | 增加类型检查:`if isinstance(x, int): ...` | | 需要纯数字八进制输出 | 切片处理:`oct(15)[2:] → '17'` | --- ### 示例代码总结 ```python # 基本转换 print(oct(8)) # 输出: '0o10' print(oct(-15)) # 输出: '-0o17' # 不同进制输入处理 print(oct(0b1101)) # 二进制13 → '0o15' print(oct(0x2F)) # 十六进制47 → '0o57' # 实际应用:权限转换 file_mode = 0o644 print(f"Linux权限: {oct(file_mode)}") # 输出: '0o644' # 异常处理演示 try: print(oct("text")) except TypeError as e: print(f"错误: {e}") # 输出: '错误: 'str' object cannot be interpreted as an integer' ``` --- ### 相关问题 1. 如何将八进制字符串转回十进制整数? 2. `oct()`函数在处理大整数时有什么限制? 3. 为什么浮点数不能直接作为`oct()`的参数? 4. 如何实现自定义进制转换函数(如三进制、五进制)? 5. Python中还有哪些其他进制转换函数
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值