一、创建字符串

>>> s1 = '12345'
>>> s1
'12345'
>>> s2 = str(12345)
>>> s2
'12345'
>>> s3 = str([1, 2, 3, 4, 5])
>>> s3
'[1, 2, 3, 4, 5]'
>>> s4 = str({'one': 1, "two": 2, "three": 3})
>>> s4
"{'one': 1, 'two': 2, 'three': 3}"

二、格式化字符串

第一种方式:

>>> s1 = 'wang'
>>> s2 = 10
>>> s3 = 'hello'
>>> s4 = s1 + s2 + s3
Traceback (most recent call last):
File "<console>", line 1, in <module>
TypeError: must be str, not int
>>> s4 = s1 + str(s2) + s3
>>> s4
'wang10hello'

第二种方式:

>>> s5 = '%s%d%s' % (s1, s2, s3)
>>> s5
'wang10hello'

Python中字符串格式化符号:

格式化操作辅助符号:

>>> num = 100
>>> '%x' % num
'64'
>>> '%X' % num
'64'
>>> '%#x' % num
'0x64'
>>> '%#X' % num
'0X64'
>>> pi = 3.1415926
>>> '%.4f' % pi
'3.1416'
>>> '%5.2f' % pi
' 3.14'
>>> pi = 3.141592
>>> '%*s' % (10, pi)
' 3.141592'
>>> d = {'one': 1}
>>> "%(one)s" % d
'1'

第三种方式:

>>>"{0} is {1} years old".format("Wilber", 28)  # 位置参数
'Wilber is 28 years old'
>>> "{name} is {age} years old".format(name = "Wilber", age = 28)  # 关键字参数
'Wilber is 28 years old'
>>> li = ["Wilber", 28]
>>> "{0[0]} is {0[1]} years old".format(li) # 下标参数
'Wilber is 28 years old'

format格式化字符串的一般形式如下:

"... {field_name!conversion:format_spec} ..."

从上面的代码可以看到,格式化字符串可分为 field_name、conversion、format_spec 三部分,分别对应替换字段名称(索引)、转换标志、格式描述。其中,字段名称是必选的,而后两者是可选的。转换标志紧跟在英文感叹号后面,而格式描述紧跟在英文冒号后面。

前面已经提到过,字段名称既可是位置索引,也可是关键字索引。字段名称后面可以通过点来访问属性,或通过方括号来访问元素。

在这里,我们重点看一下格式描述(format_spec)这一项。

格式描述中含有6个选项,分别是 fill、align、sign、width、precision、type。 它们的位置关系如下:

[[fill]align][sign][#][0][width][,][.precision][type]
fill 
可以是任意字符,默认为空格。

align 
仅当指定最小宽度时有效。

< 左对齐(默认选项)
> 右对齐
= 仅对数字有效;将填充字符放到符号与数字间,例如 +0001234
^ 居中对齐
sign 
仅对数字有效

+ 所有数字均带有符号
- 仅负数带有符号(默认选项)
 即空格;正数前面带空格,负数前面带符号
'#' 
只对整数有效

自动在二进制、八进制、十六进制数值前添加对应的 0b、0o、 0x。

',' 
自动在每三个数字之间添加 , 分隔符。

width 
十进制数字,定义最小宽度。如果未指定,则由内容的宽度来决定。

如果没有指定对齐方式(align),那么可以在 width 前面添加一个0来实现自动填充0,等价于 fill 设为 0 并且 align 设为 =。

precision 
用于确定浮点数的精度,或字符串的最大长度。不可用于整型数值。

type 
确定参数类型,默认为 s ,即字符串。

整数输出类型:

b:以二进制格式输出
c:将整数转换成对应的 unicode 字符
d:以十进制输出(默认选项)
o:以八进制输出
x:以十六进制小写输出
X:以十六进制大写输出
n:与 d 相同,但使用当前环境的分隔符来分隔每3位数字

十进制浮点数输出类型:

e:指数标记;使用科学计数法输出,用e来表示指数部分,默认 precision 为6
E:与 e 相同,但使用大写 E 来表示指数部分
f:以定点形式输出数值,默认 precision 为6
F:与 f 相同
g:通用格式;对于给定的 precision p >= 1,取数值的p位有效数字,并以定点或科学计数法输出(默认选项)
G:通用格式;与 g 相同,当数值过大时使用 E 来表示指数部分
n:与 g 相同,但使用当前环境的分隔符来分隔每3位数字
%:百分比标记;使用百分比的形式输出数值,同时设定 f 标记

>>> '{:>8}'.format('3.14')
' 3.14'
>>> '{:<8}'.format('3.14')
'3.14 '
>>> '{:^8}'.format('3.14')
' 3.14 '
>>> '{:0>8}'.format('3.14')
'00003.14'
>>> '{:a>8}'.format('3.14')
'aaaa3.14'
>>> '{:.4f}'.format(3.1415926)
'3.1416'
>>> '{:0>10.4f}'.format(3.1415926)
'00003.1416'
>>> '{:b}'.format(11)
'1011'
>>> '{:d}'.format(11)
'11'
>>> '{:o}'.format(11)
'13'
>>> '{:x}'.format(11)
'b'
>>> '{:#x}'.format(11)
'0xb'
>>> '{:#X}'.format(11)
'0XB'
>>> '{:,}'.format(15700000000)
'15,700,000,000'

  

三、字符串模板

from string import Template

s = Template("Hi, $name! $name is learning $language")
print(s.substitute(name="Wilber", language="Python")) d = {"name": "Will", "language": "C#"}
print(s.substitute(d)) # 用$$表示$符号
s = Template("This book ($bname) is 17$$")
print(s.substitute(bname="TCP/IP"))
Hi, Wilber! Wilber is learning Python
Hi, Will! Will is learning C#
This book (TCP/IP) is 17$

  

python 字符串操作一的更多相关文章

  1. Python 字符串操作

    Python 字符串操作(string替换.删除.截取.复制.连接.比较.查找.包含.大小写转换.分割等) 去空格及特殊符号 s.strip() .lstrip() .rstrip(',') 复制字符 ...

  2. python字符串操作实方法大合集

    python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换.删除.截取.复制.连接.比较.查找.分割等,需要的朋友可以参考下:   #1.去空格及特殊符号 s.st ...

  3. 转 Python 字符串操作(string替换、删除、截取、复制、连接、比较、查找、包含、大小写转换、分割等)

    转自: http://www.cnblogs.com/huangcong/archive/2011/08/29/2158268.html 黄聪:Python 字符串操作(string替换.删除.截取. ...

  4. Python 字符串操作及string模块使用

    python的字符串操作通过2部分的方法函数基本上就可以解决所有的字符串操作需求: python的字符串属性函数 python的string模块 1.字符串属性方法操作: 1.>字符串格式输出对 ...

  5. python字符串操作总结

    python中有各种字符串操作,一开始python有个专门的string模块,要使用需先import string.后来从python2.0开始,string方法改用str.method()形式调用, ...

  6. 『无为则无心』Python序列 — 17、Python字符串操作常用API

    目录 1.字符串的查找 @1.find()方法 @2.index()方法 @3.rfind()和rindex()方法 @4.count()方法 2.字符串的修改 @1.replace()方法 @2.s ...

  7. python 字符串操作。。

    #字符串操作 以0开始,有负下标的使用0第一个元素,-1最后一个元素,-len第一个元 素,len-1最后一个元素 name= "qwe , erw, qwe "print(nam ...

  8. Python 字符串操作,截取,长度

    1.字符串操作: 字符串长度: s = "; slen = len(s); 字符串截取: print s[:-:-] #截取,逆序隔1个取一个字符 print s[:-:-] #截取,逆序隔 ...

  9. python字符串操作、文件操作,英文词频统计预处理

    1.字符串操作: 解析身份证号:生日.性别.出生地等. 凯撒密码编码与解码 网址观察与批量生成 解析身份证号:生日.性别.出生地等 def function3(): print('请输入身份证号') ...

  10. python字符串操作2

    在python有各种各样的string操作函数.在历史上string类在python中经历了一段轮回的历史.在最开始的时候,python有一个专 门的string的module,要使用string的方 ...

随机推荐

  1. LRUCache 具体解释

    LRU的基本概念: LRU是Least Recently Used的缩写,最近最少使用算法. Java 实现LRUCache 1.基于LRU的基本概念,为了达到按最近最少使用排序.能够选择HashMa ...

  2. poj2595(凸包)

    Min-Max Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2192   Accepted: 502 Descriptio ...

  3. 关于数组类型的json解析方法

    遇到了非常奇葩的数组类型的json,一时解析不出来,用jsonObject会直接报错. Json数据如: [{"id":"1000142","name ...

  4. 从.Net版本演变看String和StringBuilder性能之争

    在C#中string关键字的映射实际上指向.NET基类System.String.System.String是一个功能非常强大且用途非常广泛的基类,所以我们在用C#string的时候实际就是在用.NE ...

  5. 项目Beta冲刺(团队4/7)

    项目Beta冲刺(团队4/7) 团队名称: 云打印 作业要求: 项目Beta冲刺(团队) 作业目标: 完成项目Beta版本 团队队员 队员学号 队员姓名 个人博客地址 备注 221600412 陈宇 ...

  6. DRF 之 版本控制

    1.版本控制是干什么用的,为什么要有版本? 我们都知道每一个程序都是有版本的.而且版本也会升级从v1升级到v2.v3.v4·····,但是我们不可能因为新版本出现旧版本就不去维护,因为用户有权选择不更 ...

  7. 理解yarn平台,理解万岁,肤浅理解也万岁~

    从Hadoop1到Hadoop2很大程度上解放了Jobtracker资源调度的问题,这就得多亏了yarn平台了.我知道的,除了我们的大豆瓣用的是Mesos,咱们国家可以说应该是99.99%都使用的是y ...

  8. redis中的五种基本的数据结构

    1 String 基本的数据类型. 2 list 2.1 将元素放入一个list中 rpush mylist A rpush mylist B rpush mylist A 如果mylist本来是不存 ...

  9. field 属性操作

    首先必须明一点 Field类主要是用来辅助获取和操作类的属性的! 1.怎么通过反射获取类的属性 先来看JDK提供的方法有如下几种: a)Class.getDeclaredField(String na ...

  10. redis07-----Redis持久化配置

    Redis持久化配置 持久化: 即把数据存储于断电后不会丢失的设备中,通常是硬盘. 常见的持久化方式: 主从:通过从服务器保存和持久化,如mongoDB的replication sets配置. 淘宝是 ...