Python 基礎 - 字符串常用操作
字符串常用操作
今天就介紹一下常用的字符串操作,都是以 Python3
撰寫的
首字母變大寫
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "ironman
print(name.capitalize())
---------------執行結果---------------
Ironman
計算字符串重複的字共出現幾次
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "i am a ironman"
print(name.count('a'))
---------------執行結果---------------
3
把字符串置中後,長度要50
,不足50的就用-
補滿
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "i am a ironman"
print(name.center(50, "-"))
---------------執行結果---------------
------------------i am a ironman------------------
以xx
為結尾的,就返回True,不是就False
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "i am a ironman"
print(name.endswith("an"))
print(name.endswith("i"))
---------------執行結果---------------
True
False
會把字符串中的\t
變成20個空白格,default tabsize=8
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "i \tam a ironman"
print(name.expandtabs(tabsize=20))
---------------執行結果---------------
i am a ironman
算字符串長度
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "i am a ironman"
print(len(name))
---------------執行結果---------------
14
可以透過find()
找出字符串要切片的起始位置,沒找到返回-1
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "i am a ironman"
>>> print(name.find("am"))
2 # 找到切片起始位置是2
>>> print(name[name.find("am"):3])
a
>>> print(name[name.find("am"):4])
am
>>> print(name[name.find("am"):5])
am
>>> print(name[name.find("am"):6])
am a
>>> print(name[name.find("am"):7])
am a
>>> print(name[name.find("am"):8])
am a i
>>> print(name[name.find("am"):9])
am a ir
>>> print(name[name.find("am"):10])
am a iro
>>> print(name[name.find("am"):])
am a ironman
透過formate()
對字符串做格式化
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "My name is {name} and I'm {years} old"
>>> print(name.format(name='ironman', years='18'))
My name is ironman and I'm 18 old
使用format_map()
對字符串做格式化, 替換字段使用{} 大括號
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "My name is {name} and I'm {years} old"
>>> print(name.format_map( {'name':'ironman', 'years':'18' } )) # {} 是一種字典的形式
My name is ironman and I'm 18 old
查找name
這個字符串的下標位置
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
name = "i am a ironman"
>>> print(name.index(name))
0
判斷字符串裡,是不是由數字或是大小寫英文字母組成的,為真就返回True
,若是有包含特殊符號的為就會返回False
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('123'.isalnum())
True
>>> print('abc'.isalnum())
True
>>> print('ABC'.isalnum())
True
>>> print('abc123'.isalnum())
True
>>> print('ABC123'.isalnum())
True
>>> print('abc123@'.isalnum())
False
>>> print('ABC123.'.isalnum())
False
判斷字符串,是不是所有字符都是為大小寫的英文字母,為真返回True
,反則返回False
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('ABC'.isalpha())
True
>>> print('abc'.isalpha())
True
>>> print('abc123'.isalpha())
False
>>> print('abc@'.isalpha())
False
>>> print('abc1@'.isalpha())
False
判斷字符串中,是不是為十進制的數字
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('11'.isdecimal())
True
>>> print("1234".isdecimal())
True
>>> print("12.34".isdecimal())
False
>>> print("1A".isdecimal())
False
判斷字符串中,是不是數字(整數)
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('1234'.isdigit())
True
>>> print('12.34'.isdigit())
False
判斷字符串中,是不是合法的標識符,也就是變量名
命名是否合法
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('_Python3'.isidentifier())
True
>>> print('1_Python3'.isidentifier())
False
>>> print('__Python3'.isidentifier())
True
>>> print('{Python3}'.isidentifier())
False
>>> print('我好弱'.isidentifier()) # 一般不會用中文當變量名,請勿使用
True
判斷字符串中,是不是小寫字母,不管有沒有特殊符號,為真返回True
,為否返回False
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('abc'.islower())
True
>>> print('abC'.islower())
False
>>> print('ab1'.islower())
True
>>> print('ab!@'.islower())
True
判斷字符串中,是不是數字,為真返回True
,為否返回False
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('1234'.isnumeric())
True
>>> print('12.34'.isnumeric())
False
>>> print('12A'.isnumeric())
False
判斷字符串裡,是不是空格
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print(' '.isspace())
True
>>> print('\r\t\n '.isspace())
True
>>> print('\n '.isspace()) # 換行,游標在下一行
True
>>> print('\t '.isspace()) # tab鍵,8個空格
True
>>> print('\r '.isspace()) # 換行,游標在上一行
True
判斷字符串裡,每個字母第一個字為大寫,為真返回True
,為否返回False
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('My Name Is'.istitle())
True
>>> print('My Name is'.istitle())
False
判斷字符串裡,是不是可以打印的字符串或是字符串為空,為真返回True
,為否返回False
,(不常用)
S.isprintable() -> bool
Return True if all characters in S are considered
printable inrepr() or S is empty
, False otherwise
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('My Name Is'.isprintable())
True
>>> print('123.34'.isprintable())
True
>>> print(' '.isprintable())
True
>>> print('\n'.isprintable())
False
>>> print('\t'.isprintable())
False
判斷字符串裡,每個字母是不是大寫,為真返回True
,為否返回False
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('MY NAME IS'.isupper())
True
>>> print('MY NAME iS'.isupper())
False
使用字符串作為分隔符,串連多個數據成一個字符串
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> s = ",".join(('Python', '3'))
>>> print(s)
Python,3
>>> print('+'.join(['1', '2', '3', '4']))
1+2+3+4
字符串內容往左對齊,並使用指定字符填充剩餘長度
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print(name.ljust(50, '*'))
i am a ironman************************************
字符串內容往右對齊,並使用指定字符填充剩餘長度
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print(name.rjust(50, '*'))
************************************i am a ironman
字符串轉換成小寫
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('IRONMAN'.lower())
ironman
字符串轉換成大寫
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('ironman'.upper())
IRONMAN
刪除字符串左邊空格和enter,或是指定中的字符
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> s = " i am ironman"
>>> print(s.lstrip())
i am ironman
>>> s = "i am ironman"
>>> print(s.lstrip('i am'))
ronman
刪除字符串右邊空格和enter,或是指定中的字符
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> s = "i am ironman "
>>> print(s.rstrip())
i am ironman
>>> s = "i am ironman"
>>> print(s.rstrip('man'))
i am iro
刪除字符串左右二邊空格和enter,或是指定中的字符
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('\nironman\n'.strip())
ironman
>>> s = " i am a ironman "
>>> print(':', s.strip(), ':')
: i am a ironman :
>>> s = "i am a ironman"
>>> print(s.strip('man'))
i am a iro
轉換表,請注意觀察,才會了解有什麼差異
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> p = str.maketrans("abcdef", '123456')
>>> print("i am a ironman".translate(p))
i 1m 1 ironm1n
在字符串中,把old字符串取代成new的字符串
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('ironman'.replace('i', 'I', 1))
Ironman
>>> print('ironman'.replace('r', 'R', 2))
iRonman
>>> print('i am a ironman'.replace('a', '.'))
i .m . ironm.n
在字符串中,從右邊開始找,找到最後一個的字符給打印出來下標位置
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> s = "i am a ironman"
>>> print(s.rfind("a"))
12
把字符串拆成列表
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('1+2+3+4'.split('+'))
['1', '2', '3', '4']
>>> print('1+2\n+3+4'.split('\n'))
['1+2', '+3+4']
**字符串以換行符為分隔符拆分,去掉換行符;keepends為True,保留換行符
**
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('1+2\n+3+4'.splitlines())
['1+2', '+3+4']
>>> print('1+2\n+3+4'.splitlines(keepends=True))
['1+2\n', '+3+4']
字符串裡把小寫字母變大寫,大寫字母變小寫
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('Tony Stark'.swapcase())
tONY sTARK
字符串裡每個單字的第一個字母變成大寫,其餘字母都會被轉成小寫
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('tony stark'.title())
Tony Stark
>>> print('hELLO wORLD pYTHON3'.title())
Hello World Python3
在字符串的左邊填0
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
>>> print('tony stark'.zfill(10))
tony stark
>>> print('tony stark'.zfill(20))
0000000000tony stark
參考來源:
Python 基礎 - 字符串常用操作的更多相关文章
- Python 基礎 - 文件的操作
在來我們來玩一下文件操作,這個在未來工作上,也是會很常用到的功能 Python2.7中,可以用file()來打開文件,而在Python3中,一律都是用open(),接下來在當前目錄下,先建立一個空文件 ...
- python基础之字符串常用操作总结
字符串的索引 s = 'ABCDLSESRF' # 索引 这两个很简单没什么说的 s1 = s[0] print(s1) # A s2 = s[2] print(s2) # C 切片 s = 'ABC ...
- Python文本和字符串常用操作
## 字符串分割 line = "This is my love!" fields = line.split(' ') print(fields) # ['This', 'is', ...
- Python 基礎 - 字典的操作使用
接下來介紹字典,這在未來工作上,會是很常使用的,就來好好了解一下唄- 字典是一個 key(鍵)-value(值) 的數據類型,可以儲存很多訊息 #!/usr/bin/env python3 # -*- ...
- 初识python: 字符串常用操作
直接上代码示例: #!/user/bin env python # author:Simple-Sir # time:20180914 # 字符串常用操作 name = 'lzh lyh' print ...
- Python学习笔记五:字符串常用操作,字典,三级菜单实例
字符串常用操作 7月19日,7月20日 ,7月22日,7月29日,8月29日,2月29日 首字母大写:a_str.capitalize() 统计字符串个数:a_str.count(“x”) 输出字符, ...
- Python 基礎 - if else流程判斷
hmm~前面講了那麼多,終於可以稍稍的正式進入另一個階段,沒錯,要開始寫判斷式了 這次先從最簡單的判斷式開始,if else 開始- Go 首先,之前有寫有一個簡單的互動式 用戶輸入 的代碼,忘記了嗎 ...
- python基础(字符串常用、数字类型转换、基本运算符与流程控制)
一.字符串常用操作: #! /usr/bin/env python # -*- coding: utf-8 -*- # __author__ = "Z'N'Y" # Date: 2 ...
- Python3笔记022 - 5.1 字符串常用操作
第5章 字符串及正则表达式 5.1 字符串常用操作 5.1.1 拼接字符串 使用+运算符可完成多个字符串的拼接,产生一个新的字符串对象. str1 = "2020年07月06日是" ...
随机推荐
- Ext4 ComboBox组件使用
先来看例子: Ext.define('schoolModel', { extend: 'Ext.data.Model', fields: [{ name: 'id', type: 'string' ...
- windows C input 注意
windows控制台输入,默认是以文本模式打开,即使重定向输入,文本模式不变,所以输入时无法读到cr,因为windows已经把crlf转换成单个lf. 如果freopen("CON" ...
- Eclipse 离线安装ADT
由于小猪的Eclipse中ADT版本过低无法打开Android项目了,所以要更新ADT(Android Develop Tools),但是在国内由于谷歌与本国微妙的关系想自动安装总是卡在某个点上. 所 ...
- JAVA动手动脑
1.运行 TestInherits.java 示例,观察输出,注意总结父类与子类之间构造方法的调用关系修改Parent构造方法的代码,显式调用GrandParent的另一个构造函数,注意这句调用代码是 ...
- [转载]Three Trending Computer Vision Research Areas, 从CVPR看接下来几年的CV的发展趋势
As I walked through the large poster-filled hall at CVPR 2013, I asked myself, “Quo vadis Computer V ...
- python cmd下运行中文乱码 策略
如我运行一个脚本,执行后输出中文看不懂 然后呢在文件头加上 from __future__ import unicode_literals 注意:需要去掉所有字符串前的 u, 这样所有字符串均默认为u ...
- VS一次删除多个窗体后报错
今天在做项目的时候,需要删除多个窗体,删除了之后,VS报了个错误: 命名空间“项目名称”中不存在类型或命名空间名称“文件夹”(是否缺少程序集引用?) 具体原因不清楚,就算恢复窗体后还是一样的错误,无法 ...
- mysql使用
1.以查询结果建表 create table newTableName select column1 [newName1] [, column2 [newName2], .. , columnn [n ...
- 转 从腾讯那“偷 了”3000万QQ用户数据
http://www.icaijing.com/hot/article4899809/ http://news.cnblogs.com/n/533061/
- 【转】关于Oracle将小于1的数字to_char后丢掉0的解决办法
SQL代码如下: select rtrim(to_char(0.11, 'fm9990.99'), '.') from dual; 其中0.11为需要to_char的数字fm去掉字符串前面的空格999 ...