原文链接:http://www.one2know.cn/python3/

  • 字典排序

    dict = {'a':1,'c':3,'b':2}

    字典没有sort方法,可使用sorted排序,默认通过key排序

    dict = sorted(dict),print(dict)key的排序

    dict = sorted(dict,reverse = True),print(dict)逆序key

    dict = sorted(dict.items),print(dict)key-value作为元组的排序列表

    dict = sorted(dict.items),print({k:v for k,v in dict})实现字典的排序

    使用lambda排序:
dict = sorted(dict.items(),key = lambda x:x[1],reverse = True)
#x[1]表示按照value排序,因为ict.items()是元组的列表,x[1]是元组的第二项即value,赋给要排序的关键字key
print({k:v for k,v in dict})
#用字典推导式将得到的元组列表转换成字典输出
  • 字典列表排序
list = [{name':b,'age':17},{name':a,'age':15},{'name':c,'age':16}]
dict = sorted(list,key= lambda x:x['age'],reverse = True)
#按age排序,倒序,不给key的话默认用第一个属性排
print(dict)
#输出的还是字典列表
  • 常用内置函数

    abs(num) sorted(list) sum(list) round(a,b)小数点后取b位 eval()执行一个表达式,或字符串作为运算 exec()输出python语句
  • 常用高阶函数

    map(func,seq[,seq...])映射
list = [1,2,3,4,5]
newlist = map(lambda x : x*2,list) #还不如newlist = [x*2 forx in list]方便!
print(newlist)
print(list(newlist)) #将map对象转换为list打印
list2 = [3,4,5,6,7]
newlist2 = map(lambda x,y : x*y,list,list2) #map后多个对象的例子

filter(func,seq)过滤

list = [1,2,3,4,5]
newlist = filter(lambda x:x>2,list)
print(list(newlist)) #输出:[3,4,5]
#用map试试
newlist = map(lambda x:x>2,list)
print(list(newlist)) 输出:[false,false,true,true,true]

reduce(func,seq[,初始值])

from functools import reduce
list = [1,2,3,4,5]
list2 = [3,4,5,6,7]
newlist = reduce(lambda x,y : x+y,list,10)
#10是初始值,默认为0,第一步就是x=10
print(newlist) #输出:25
  • 类定义
class 类名():
#类文档说明
属性
方法

例子:

#创建person类
class person():
'''
这是一个人类
'''
country = 'china' #声明类属性,并赋值
#实例属性通过构造方法来声明
#self不是关键字,代表的是当前对象
def __init__(self,name,age,sex): #构造方法
#构造方法不需要调用,在实例化时自动调用
print('我是构造方法,在实例化时调用')
self.name = name #通过self,创建实例属性,并赋值
self.age = age
self.sex = sex
#创建普通方法
def getName(self):
#在方法里面使用实例属性
print('我叫%s,来自%s'%(self.name,person.country)) #实例化对象
people01 = person('joe',18,'男') #在实例化时传递参数
#这个people01有3个属性和1个方法 #访问属性
#通过 对象名.属性名 访问实例属性
print(people01.name)
print(people01.age)
print(people01.sex) print(getattr(people01,'name')) #通过内置方法访问属性
print(hasattr(people01,'name')) #是否有该属性,返回bool
print(setattr(people01,'name','susan')) #修改属性
delattr(people01,'name')) #删除属性 #通过对象调用实例方法
people01.getName() #内置类属性
print(people01.__dict__) #将对象的属性通过字典形式返回
print(people01.__doc__) #查看文档说明(输出:这是一个人类)
print(person.__name__) #返回类名,不知道有啥用
print(people01.__bases__) #返回基类,也不知道有啥用
  • __name__
package name
def a():
print('我是a方法')
if __name__ == '__main__': #判断是否在当前脚本运行
a()
print(__name__) #在当前脚本运行,输出:__main__

在另一个文件引用:

package name2
import name #没有输出
  • 继承
class Animal():
def __init__(self,name,food):
self.name = name
self.food = food
def eat(self):
print('%s eat %s'%(self.name,self.food)) class Dog(Animal):
def __init__(self,name,food,drink):
#加载父类构造方法
super().__init__(name,food)
#或者Animal.__init__(self,name,food)也行
self.drink = drink #子类自己的属性
def drinks(self): #子类自己的方法
print('%s drink %s`%(self.name,self.drink)) if __name__ = '__main__':
dog1 = Dog('金毛','骨头','可乐')
dog1.eat()
dog1.drinks()
  • 多继承:若父类有相同的属性或方法,从左往右找
class A():
def a(self):
print('Aa')
class B():
def b(self)):
print('Bb')
def a(self)):
print('Ba')
class C():
def c(self)):
print('Cc')
class D(A,B,C):
def d(self)):
print('Dd') dd = D()
dd.d() #调用自己的方法
dd.a() #输出:Aa
  • 多态:重写
class A():
def a(self):
print('Aa')
class B(A)
class D(A):
def a(self)):
print('Da')
bb = B()
bb.a() #输出:Aa
dd = D()
dd.a() #输出Da
  • 私有属性(相当于private)

    双下划线开头的属性,不能通过 对象名.属性名 访问和修改!

    外部修改私有属性,预留一个接口修改或访问,如
def getAddre(self,pwd):
if pwd == '123':
return self.__address
else:
return '权限不够' #强制访问,尽量不这样做
print(people01._person__address)
  • 静态方法和类方法
@staticmethod #静态方法:不能访问实例属性,只能访问类属性
def aa(): #不需要传递实例,没有self
print(person.country)
people01.aa()
person.aa() #推荐使用通过类名来调用静态方法 @classmethod #类方法:不能访问实例属性,
def bb(cls):
print(cls.country)
people01.bb()
person.bb() #推荐使用通过类名来调用类方法
  • 模块:官方,第三方,每一个脚本都是一个模块

    同一目录直接引用,不同目录从两个文件的最高相同目录开始from

    创建一个包一定要创建一个__init__.py文件,里面有__all__ = ['moduel1','moduel2',...]表示运行被允许导入的模块
  • 重新加载:模块被导入一次后,其他的导入不再有效
import test
import imp
imp.reload(test)

Python 基础 (三)的更多相关文章

  1. Python 基础 三 反射

    Python 基础 三 反射 今天我们先介绍一下反射这个概念,啥是反射?反射就是自己检测自己.在我们Python的面向对象中的反射是啥意思呢?就是通过字符串的形式操作对象相关的属性.python中的一 ...

  2. 进击的Python【第三章】:Python基础(三)

    Python基础(三) 本章内容 集合的概念与操作 文件的操作 函数的特点与用法 参数与局部变量 return返回值的概念 递归的基本含义 函数式编程介绍 高阶函数的概念 一.集合的概念与操作 集合( ...

  3. Python 基础三 文件 函数

    今天回顾一下之前学的文件操作相关知识点,对于文件的操作,主要有一下几部分构成: 一.文件的基础知识 1.文件操作的基本流程 文件操作其实可以分成三大部分: 1.打开文件,获取文件句柄并赋予一个变量 2 ...

  4. python基础三

    多级菜单 多级菜单 可依次选择进入各子菜单 所需新知识点:列表.字典 #!/usr/bin/env python # -*- coding: utf-8 -*- menu = { '北京':{ '海淀 ...

  5. Python基础三. 函数、lambda、filter、map、reduce

    一.概述 函数, 就是用一些语句组织起来实现一组特定的功能, 用来重复调用. 函数的作用及意义:最大化的重用代码和最小化的代码冗余以及对流程的分解. Python中有哪些函数: 内建的函数 第三方模块 ...

  6. Python基础(三)——集合、有序 无序列表、函数、文件操作

    1.Set集合 class set(object): """ set() -> new empty set object set(iterable) -> n ...

  7. python基础(三)

    set集合 set集合创建 #方式1: se = {'} #与字典类似dict1 = {'k1','v1','k2','v2'} #方式2: se = set() #创建一个空的集合 list1 = ...

  8. 【笔记】Python基础三:文件

    一,文件操作 (一),文件处理流程 1,打开文件,获得文件句柄(open函数提供)并赋值 2,通过句柄对文件进行操作 3,关闭句柄 f = open('陈粒',encoding='utf-8')#op ...

  9. Python基础三(选择,循环)

    序 首先我们知道程序的执行有三种结构:顺序.选择.循环三种结构,而为了方便我们书写和多次利用我们就需要把一段代码封装器来,这就是方法.今天我就说的是程序的基本结构的格式和方法. 注:所有的程序都可以通 ...

  10. Python基础(三) 数据类型

    我们首先要看的是几乎任何语言都具有的数据类型,包括字符串.整型.浮点型以及布尔类型.这些基本数据类型组成了基本控制块,从而创建的Python应用程序. 一.基本结构 1.数值: Python支持不同的 ...

随机推荐

  1. 网站性能优化的方法--Yahoo

    如何能让用户更快的打开我们的网页? 1.尽可能减少HTTP请求数 2.使用CDN(内容分发网络) 3.添加Expire/Cache-Control头 4.启用Gzip压缩 5.将CSS放在页面最上面 ...

  2. Android:JNI与NDK(二)交叉编译与动态库,静态库

    欢迎关注公众号,第一时间获取最新文章: 本篇目录 一.前言 本篇主要以window开发环境为背景介绍一下NDK开发中需要掌握的交叉编译等基础知识,选window系统主要是照顾大多数读者,mac ,li ...

  3. 【iOS】receiver type *** for instance message is a forward declaration

    错误原因:没有引入相关的头文件 http://stackoverflow.com/questions/8815200/receiver-type-for-instance-message-is-a-f ...

  4. CountDownLatch实现多线程并发请求

    package com.test; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Dat ...

  5. Hyper-V虚拟机上安装Ubuntu16.04/Ubuntu18.04.2LTS,搭建GitLab

    我的电脑系统是win10,内存8g如下 一开始是装的Ubuntu18.04.2LTS, gitlab-ce_12.1.3-ce.0_amd64.deb,每次能够安装成功,但是修改完ip后,运行gitl ...

  6. Spark 系列(四)—— RDD常用算子详解

    一.Transformation spark 常用的 Transformation 算子如下表: Transformation 算子 Meaning(含义) map(func) 对原 RDD 中每个元 ...

  7. dotnetcore 与 hbase 之一——hbase 环境准备

    转载请注明出处www.cnblogs.com/hsxian! 总述 这是一系列针对 .net core (c#) 读取 hbase 的教程.本人苦于找不到 c#的原生 hbase 客户端,多番寻觅之下 ...

  8. FLV协议5分钟入门浅析

    FLV协议简介 FLV(Flash Video)是一种流媒体格式,因其体积小.协议相对简单,很快便流行开来,并得到广泛的支持. 常见的HTTP-FLV直播协议,就是使用HTTP流式传输通过FLV封装的 ...

  9. Rootkit与后门隐藏技术

    目录 简介 linux虚拟文件系统VFS rootkit的功能 隐藏文件 基本方法 高级方法 系统调用流程 hook sys_getdents sys_getdents的调用树 最底层的方法 隐藏进程 ...

  10. [Spring cloud 一步步实现广告系统] 22. 广告系统回顾总结

    到目前为止,我们整个初级广告检索系统就初步开发完成了,我们来整体回顾一下我们的广告系统. 整个广告系统编码结构如下: mscx-ad 父模块 主要是为了方便我们项目的统一管理 mscx-ad-db 这 ...