开始学习python语言的第三天,跟着廖雪峰老师的教程一步步学习,学到了高阶函数编程。前面的基础课程,从编译器使用开始,到基础部分的变量,判断,循环,数据结构,到现在的高阶函数编程,决定做些习题练练手。题目为将不规则的英文名变为首字母大写其余小写的规范字符串,题目非常简单,但运用到了python语言的基础部分。
首先想到的是用循环逐个改变字符的大小写,这里用到自带函数upper()和lower(),分别将字符转换为大写和小写。
m_na = ''
def normalize(name):
global m_na
m_na = ''
key = True
for ch in name:
if ch == name[0:1] and key:
m_na += ch.upper()
key = False
else:
m_na += ch.lower()
return m_na
曾经的C++学习告诉我,永远不要返回一个局部变量,但是python中无法直接在函数中修改一个外部定义的变量,必须加上global关键字,才可以完成修改。
这样便完成第一阶段。那么假如接受到的是一个List形式的带有多个字符串的入参呢?循环的调用normalze函数未免太繁琐,这个时候map()函数可以帮助我们解决问题。
我们先看map。map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回。
了解了map()函数的功能后,现在来实现这个多个字符串规范的需求
L1 = ['adam','LISA','barT']
m_na = ''
def normalize(name):
global m_na
m_na = ''
key = True
for ch in name:
if ch == name[0:1] and key:
m_na += ch.upper()
key = False
else:
m_na += ch.lower()
return m_na
L2 = list(map(normalize,L1))
print(L2)
这样便完成了第二阶段。python语言追求的简洁明了,用最少的代码做最多的事情,那么需要讲这段代码再一次优化。上面的代码仅仅用到了python语言高级特性切片的基础功能,既然能截取到第一个字符,那么后面的字段是否也能用切片完成截取呢,有了这个思路,继续改造程序
def normalize(name):
return name[0].upper()+name[1:].lower()
print(list(map(normalize,L1)))
接收name字符串后,直接返回操作,+运算符可以讲字符直接拼接起来,因为python的底层是用C实现的,对+进行了操作符重载,类似C++中的string类。