Python字符串基础操作
==============字符串========
>>> s1='www.baidu.com'
>>> type(s1)
<type 'str'>
>>> type(2)
<type 'int'>
>>> type("'dsfdsjk'")
<type 'str'>
用type()测一下是什么类型
字符串的访问 s1[0]=’ s1[2]=w 用下标来访问
>>> s6='aa\nbb'
>>> print s6
aa
bb
>>> #/n是转义字符,表示换行符 各种换行符如图记载
>>> s6='aa\nbb'
>>> print s6
aa
bb
>>> s7=r'aa\nbb' #当加上r的时候就是不转义的意思【关闭转义机制】
>>> print s7
aa\nbb
>>> s8=u'aa\nbb' #当加上u的时候表示后面跟的字符串是unicode编码
>>> print s8
aa
bb
>>> ‘%10s%10d%10.2f’%(‘record’,21,25.652) 格式化字符串 %s格式化为字符串 %d格式化为整数 %f格式化为浮点数(反正前面有几个格式占位符这边就几个逗号隔开的对应值)10.2f表示浮点数占10位小数点后面保留2位 四舍五入
>>> print 'name %s age %d record %f'%('amily',25,99.9)
name amily age 25 record 99.900000
>>> s1='www.baidu'
>>> s2='.com'
>>> print s1+s2 # +加号字符串连接 +前后必须都是字符串类型
www.baidu.com
>>> s1='hello amily'
>>> s2=2
>>> print s1+str(s2) 转换为字符串类型再进行加法运算
hello amily2
>>> li1=[1]*5 #*星号 字符串重复 等于N个加法 *前为字符串*后为数字
>>> print li1
[1, 1, 1, 1, 1]
>>> li2=['aa']*5
>>> print li2
['aa', 'aa', 'aa', 'aa', 'aa']
>>> s1='111'*20
>>> print s1
111111111111111111111111111111111111111111111111111111111111
>>> s1='www.baidu.com'
>>> print s1[4] #通过[]下标访问字符串的第几个位置的值 str[index]
b
>>> s1='www.baidu.com'
>>> print s1[-4] #负数也可以,负数就是从右边为起点
.
>>>
>>> print s1[2:4] # str[start:end] 切片 start切片起点 end切片终点起点或者终点可以不填 写负数就是从右边开始
w.
>>> #这里切片起点必须小于终点,因为是从左向右切的。
如果要从右向左切片, 则str[big:small:-1], 这样是逆序输出
>>> s1='www.baidu.com'
>>> print s1[8:3:-1]
udiab
>>> s1='www.baidu.com'
>>> print s1[-1::-1] #实现字符串的逆序输出
moc.udiab.www
>>>
字符串其他常用函数
>>> s='dafdfh234234hjk'
>>> s.isalnum() #str.isalnum 判断字符串中是否均为数字或者字母
True
>>> s='sadfhd.?<dfah'
>>> s.isalnum()
False
>>>
>>> s='sdfhdjshf0'
>>> s.isalpha() #str.isalpha判断字符串中是否均为字母
False
>>> s='dfdfhdgf'
>>> s.isalpha()
True
>>> s='132746'
>>> s.isdigit() #str.isdigit判断字符串中是否均为数字
True
>>> s='sdfgydh678'
>>> s.isdigit()
False
>>> s='ABV'
>>> s.isupper() #str.isupper判断字符串中是否均为大写字母
True
>>> s='dfhu'
>>> s.islower() #str.islower判断字符串中是否均为小写字母
True
>>> s=''
>>> s.isspace() #str.isspace 判断字符串是否为空格
False
>>> s=' '
>>> s.isspace()
True
>>> s='djfdjsfh'
>>> s.upper() #str.upper字符串转化为大写字母
'DJFDJSFH'
>>> s='DJKJSDJFK'
>>> s.lower() #str.lower字符串转化为小写字母
'djkjsdjfk'
>>> s='DJKJSDJFK'
>>> s.lower()
'djkjsdjfk'
>>> s='dfhAJKH'
>>> s.upper()
'DFHAJKH'
>>> s.lower()
'dfhajkh'
>>> s=' dsjfhdsjkf kdjfhj '
>>> s.strip() #str.strip是去除某字符串左右的一个或多个空格(广义空格,\n,\t)
可以写成str.strip(‘\n’)
#str.split()前后中间的空格都能去掉
'dsjfhdsjkf kdjfhj'
>>> s.rstrip() #str.rstrip 是去除字符串右边的空格(可以去掉多个空格)
' dsjfhdsjkf kdjfhj'
>>> s.lstrip() #str.lstrip 是去除字符串左边的空格(可以去掉多个空格)
'dsjfhdsjkf kdjfhj '
#coding:utf-8
s='www.baidu.com'
s1='www'
s2='.com'
if s.startswith(s1): #str.startswith(str1) 判断字符串是否以str1开始,返回布尔值
print 'www'
if s.endswith(s2): #str.endswith(str1)判断字符串是否以str1结束,返回布尔值
print '.com'
>>> s='www.baidu.com'
>>> id(s) #id(str)查看字符串在内存中的地址
46351608
>>> s1=s.replace('b','B') #str.replace(‘a’,’b’)将字符串中的a全部替换为b
>>> id(s1)
46353008
>>> s=s.replace('w','S') #可以看到replace函数“修改了”原来的字符串,字符串位置改变了,说明其实不是原来的字符串了,so字符串是不可以被修改的,只是产生了一个新的字符串罢了
>>> id(s)
46353808
>>> print s
SSS.baidu.com
>>> s=' dsfdsf f d 234h djfha '
>>> li=s.split() #str.split()字符串分割,返回一个list类型
>>> print li
['dsfdsf', 'f', 'd', '234h', 'djfha']
这个其实用split可以直接实现,但是这里最重要的是思路的循序渐进。写比较复杂的算法一定要有循序渐进的思路,慢慢来,一点点的去实现,然后在组合在一起,尤其是循环的这种一次找不到规律,可以逐步的走几个循环,找到规律再写while或者for语句。
#coding:utf-8
def Mysplit(s):
s=s.strip()
while(s.find(' ')!=-1):
index1=s.find(' ')
s1=s[:index1]
s=s[len(s1):]
s=s.lstrip()
print s1
else:
print s
Mysplit(' dsfdsf f d 234h djfha hfkdjfdjd dkfdk dkfjadkjf dfajkdf adkfasdfhjd 34737 ')
str.split()细讲 记录split()返回的是list类型的 以sth为分隔符,分割N次(分为N+1份),取第几份。Split(‘m’,n)[x]
>>> 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('\n')
['say', 'hello', 'baby']
分离文件名与路径
>>> os.path.split('/dodo/soft/python')
('/dodo/soft', 'python')
>>> os.path.split('/dodo/soft/python/')
('/dodo/soft/python', '')
好例子
>>> str='hello hahaha<[www.baidu.com]>gdf238728'
>>> print str.split('[',1)[1].split(']',1)[0]
www.baidu.com
>>> print str.split('[',1)[1].split(']',1)[0].split('.')
['www', 'baidu', 'com']
>>>
Python字符串基础操作的更多相关文章
- Python文件基础操作(IO入门1)
转载请标明出处: http://www.cnblogs.com/why168888/p/6422270.html 本文出自:[Edwin博客园] Python文件基础操作(IO入门1) 1. pyth ...
- Python字符串切片操作知识详解
Python字符串切片操作知识详解 这篇文章主要介绍了Python中字符串切片操作 的相关资料,需要的朋友可以参考下 一:取字符串中第几个字符 print "Hello"[0] 表 ...
- Python字符串基础一
下一篇:Python 序列通用操作介绍 写在前面 下学期开始上计算机网络的课程,现在已经在看相关书籍,希望结合python写出一个网络爬虫程序.利用学习C++后的空余时间来看看Python并在这里总结 ...
- Python 字符串大小写操作
#coding=utf-8 #python中字符串的操作 # 字符串的大小写 s='hello_wOrld_oF_you' upper_str = s.upper() print('全部大写: ',u ...
- Python字符串的操作
字符串常用操作 name = "my name is alex" # 注: python中方法名前后带下划线的是供内部使用的方法, 如方法__dir__(). 这种方法是不对外提供 ...
- day7 python字符串的操作及方法
1.字符串 1.1 字符串的操作 # 1.字符串的拼接 strvar = "我爱" + "中国" # 2.字符串的重复 strvar = "今天下午2 ...
- python字符串基础知识
1.python字符串可以用"aaa",'aaa',"""aaa""这三种方式来表示 2.python中的转义字符串为" ...
- Python—字符串的操作
字符串的操作 变量: 变量只能是 字母,数字或下划线的任意组合,但首个字符不能为数字,且不能有空格 以下关键字不能声明为变量: and ,as, assert, break ,class ,conti ...
- python字符串的操作(去掉空格strip(),切片,查找,连接join(),分割split(),转换首字母大写, 转换字母大小写...)
#可变变量:list, 字典#不可变变量:元祖,字符串字符串的操作(去掉空格, 切片, 查找, 连接, 分割, 转换首字母大写, 转换字母大小写, 判断是否是数字字母, 成员运算符(in / not ...
随机推荐
- Android Studio上方便使用butterknife注解框架的偷懒插件Android Butterknife Zelezny
首先提下ButterKnifey已经更新到版本7.0.1了,现在注解已经不叫@InjectView了,而叫@Bind,感觉更贴合语义.同时注册的方式也从 ButterKnife.inject(this ...
- WPF开发时光之痕日记本——终于完工了。。晒晒截图(三)(已上传安装包)
由于是业余时间学习的 WPF 的相关开发且不怎么会使用 Blend 软件,所以开发这个客户端着实花费了我很长时间,比如文本编辑器的开发,最初是在 Simple.HtmlEditor 的基础上做的修改, ...
- 按照需要分别率长宽比导出图片(python 3)
效率提升的问题 之前朋友需要把大量的图片用分辨率进行区分查找,他说都是打开图片,然后用尺子在屏幕上量......我也是瀑布汗....花的点时间帮他写的小软件,解决这个蛋疼的问题 解决方案 本想用批处理 ...
- [BZOJ1070][SCOI2007]修车(最小费用最大流)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1070 分析: 把每个工人拆成N个点.记为A[i,j]表示第i个工人修倒数第j辆车. 每 ...
- [BZOJ 2656][ZJOI2012]数列(递归+高精度)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2656 分析: 很容易想到递归分治,但遇到奇数时候f[i]=f[i/2]+f[i/2+1 ...
- 微信支付PHP SDK —— 公众号支付代码详解
在微信支付 开发者文档页面 下载最新的 php SDK http://mch.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1 这里假设你已经申请完微 ...
- .Net MVC中访问PC网页时,自动切换到移动端对应页面
随着移动端的流行,越来越的网站,除了提供PC网页之外,也提供了移动端的H5页面,手机在访问www.xxx.com的时候,能自动跳转到mobile.xxx.com.网上很多在实现时也能使用JS直接进行跳 ...
- Linux_Centos使用mutt+msmtp发送邮件
一.软件环境 1.centos 6.5 2.msmtp-1.4.32 3.Mutt 1.5.20 (2009-12-10) 二.实现步骤 1.安装配置Mutt $ yum install mutt - ...
- Oracle查看锁表
查看锁表进程SQL语句1: select sess.sid, sess.serial#, lo.oracle_username, lo.os_user_name, a ...
- 淘宝业务常用english
ADX ad exchange 广告交易平台 coupon 赠品 CPC cost per click CPS cost per sales CT ...