流程如下:
1、得到字符串s,通过分割提取得到s1(是个列表)
s=”name=lyy&age=3&sex=women&boyfriend=czt”
2、需要再对s1进行拆分,此时s1只有4个元素,对s1进行遍历,拿到类似“name=lyy”的字符串,即s2
3、同样通过分割把s2分割成s3列表
4、s3为[name,lyy],即为字典的键和值赋值,键=s3[0],值=s3[1]
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
# -*- coding: utf-8 -*- s = "name=lyy&age=3&sex=women&boyfriend=czt" d = { } s1 = s.split( "&" ) # print s1 for i in xrange ( 4 ): s2 = s1[i] # print s2 s3 = s2.split( "=" ) print s3 key = s3[ 0 ] value = s3[ 1 ] d[key] = value print d |
改进代码,改进之处——直接使用s2 in s1执行遍历
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
# -*- coding: utf-8 -*- s = "name=lyy&age=3&sex=women&boyfriend=czt" d = { } s1 = s.split( "&" ) # print s1 for s2 in s1: s3 = s2.split( "=" ) print s3 key = s3[ 0 ] value = s3[ 1 ] d[key] = value print d |
二、把一个字典中的内容提取出来,并存储为字符串
流程如下:
1、把字典中的项目取出来,使用items方法,使得字典的键值对变成列表s1的每一个元素,s1是列表
2、遍历s1的每一个元素,先需要读取每一个元素的键和值,即key=s1[0],value=s1[2]
3、这时key和value分别都是字符串,用“=”连接起来
4、把每一个等式连接起来使用到append方法,创建列表存储每次连接好的等式
5、使用列表的join方法,把“&”插入列表中
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
# -*- coding: utf-8 -*- d = { 'age' : '3' , 'boyfriend' : 'czt' , 'name' : 'lyy' , 'sex' : 'women' } s1 = d.items() lst = [] print s1 for i in xrange ( 4 ): s2 = s1[i] print s2 key = s2[ 0 ] value = s2[ 1 ] print key print value s3 = key + "=" + value print s3 lst.append(s3) print lst print "&" .join(lst) |
同样简化步骤,循环内语句这样写:
1
2
3
4
5
|
for s2 in s1: key = s2[ 0 ] value = s2[ 1 ] s3 = key + "=" + value lst.append(s3) |
s2里面对应就是两个元素,简化:
1
2
3
4
|
for s2 in s1: key,value = s2 s3 = key + "=" + value lst.append(s3) |
发现s2同样可以省略,但是上述的key和value连接依赖s2,可用格式化成字符串输出来摆脱这种依赖,简化如下
1
2
3
4
5
6
7
8
9
|
# -*- coding: utf-8 -*- d = { 'age' : '3' , 'boyfriend' : 'czt' , 'name' : 'lyy' , 'sex' : 'women' } s1 = d.items() lst = [] for key,value in s1: s3 = "%s=%s" % (key,value) lst.append(s3) print "&" .join(lst) |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/LYYCasablanca000/article/details/60585031