Python笔记

1、匿名函数lambda 

python 使用 lambda 来创建匿名函数。

所谓匿名,意即不再使用 def 语句这样标准的形式定义一个函数。

  • lambda 只是一个表达式,函数体比 def 简单很多。
  • lambda的主体是一个表达式,而不是一个代码块。仅仅能在lambda表达式中封装有限的逻辑进去。
  • lambda 函数拥有自己的命名空间,且不能访问自己参数列表之外或全局命名空间里的参数。
c = {"a": [13, 2, 5, 6, 7], "b": [44, 23, 45, 73, 24], "c": [465, 86, 35, 245, 45], "d": [5, 5, 22, 4]}
print(c["a"][0])
for num in sorted(c, key=lambda x: c[x][0], reverse=True):
    print(num)

2、获取文件名方法:

from os import path
import re
1.分割路径,返回路径名和文件加扩展名的元组,取第二个元素,再分离文件名和扩展名
file = path.split('/root/runoob.txt')[1]
filename = path.splitext(file)[0]
print(filename)
2.分割路径,返回路径名和文件加扩展名的元组,取第二个元素,再替换扩展名为空
file = path.split('/root/runoob.txt')[1]
filename = re.sub(".txt", "", file, count=0, flags=re.I)
print(filename)
3.先获取文件名加扩展名,再替换扩展名为空
file = path.basename('/root/runoob.txt')
filename = re.sub(".txt", "", file, count=0, flags=re.I)
print(filename)
4.先获取文件名加扩展名,再分割文件和扩展名,取第一个元素
filename = path.splitext(path.basename('/root/runoob.txt'))[0]
print(filename)


3、python对XML的解析

常见的XML编程接口有DOM和SAX,这两种接口处理XML文件的方式不同,当然使用场合也不同。

python有三种方法解析XML,SAX,DOM,以及ElementTree:

1.SAX (simple API for XML )
python 标准库包含SAX解析器,SAX用事件驱动模型,通过在解析XML的过程中触发一个个的事件并调用用户定义的回
调函数来处理XML文件。

2.DOM(Document Object Model)
将XML数据在内存中解析成一个树,通过对树的操作来操作XML。

3.ElementTree(元素树)
ElementTree就像一个轻量级的DOM,具有方便友好的API。代码可用性好,速度快,消耗内存少。

注:因DOM需要将XML数据映射到内存中的树,一是比较慢,二是比较耗内存,而SAX流式读取XML文件,比较快,占用
内存少,但需要用户实现回调函数(handler)。

将XML数据在内存中解析成一个树,通过对树的操作来操作XML
from xml.etree import ElementTree as ET
tree = ET.parse(filename)
            
root = tree.getroot()
            
style_result = root.find('actions').find('hudson.plugins.checkstyle.CheckStyleResultAction/result')
   
delta_total = int(style_result.find('numberOfWarnings').text)

4、os.walk()

概述
os.walk() 方法用于通过在目录树种游走输出在目录中的文件名,向上或者向下。在Unix,Windows中有效。
语法
walk()方法语法格式如下:
os.walk(“路径”, topdown=True/False)
返回目录路径下的每一个文件夹(包含它自己), 产生3-元组 (dirpath, dirnames, filenames)【文件夹路径, 文件
夹名字, 文件名】
实例:

import os
for root, dirs, files in os.walk("D:\Public_Tools", topdown=True):
    for name in files:
        print(name)
        print(os.path.join(root, name))
    for name in dirs:
        print(name)
        print(os.path.join(root, name))

5、斐波那契额数列
 

a = 0
b = 1
while b < 10:
    print(a, end=" ")
    a, b = b, a + b
################函数
def fibonacci(n):  
    a, b, counter = 0, 1, 0
    x = set()
    while counter < n:
        x.update([a])
        a, b = b, a + b
        counter += 1
    return x


if __name__ == '__main__':
    print(fibonacci(10))

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值