python基本使用-python基本用法笔记合集
PYTHONPATH
PYTHONPATH是python moudle的搜索路径.即import xxx会从$PYTHONPATH寻找xxx.
中文编码问题
coding=utf-8
查看导入的包的路径
import a_module
print(a_module.file)
map(function, iterable, ...)
参数
function -- 函数
iterable -- 一个或多个序列
返回值
Python 2.x 返回列表。
Python 3.x 返回迭代器。
>>>def square(x) : # 计算平方数
... return x ** 2
...
>>> map(square, [1,2,3,4,5]) # 计算列表各个元素的平方
[1, 4, 9, 16, 25]
>>> map(lambda x: x ** 2, [1, 2, 3, 4, 5]) # 使用 lambda 匿名函数
[1, 4, 9, 16, 25]
# 提供了两个列表,对相同位置的列表数据进行相加
>>> map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10])
[3, 7, 11, 15, 19]
What is :: (double colon) in Python when subscripting sequences?
It returns every item on a position that is a multiple of 3. Since 3*0=0, it returns also the item on position 0. For instance: range(10)[::3] outputs [0, 3, 6, 9]
每隔xxx个元素做切片
transpose
比如img是h*w*c维(h是第0维,w是第1维,c是第2维)的矩阵. 在经过transpose((2,0,1))后变为c*h*w的矩阵
enumerate
>>>seasons = ['Spring', 'Summer', 'Fall', 'Winter']
>>> list(enumerate(seasons))
[(0, 'Spring'), (1, 'Summer'), (2, 'Fall'), (3, 'Winter')]
>>> list(enumerate(seasons, start=1)) # 下标从 1 开始
[(1, 'Spring'), (2, 'Summer'), (3, 'Fall'), (4, 'Winter')]
range(start, stop[, step])
start: 计数从 start 开始。默认是从 0 开始。例如range(5)等价于range(0, 5);
stop: 计数到 stop 结束,但不包括 stop。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5
step:步长,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)
>>>range(10) # 从 0 开始到 10
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> range(1, 11) # 从 1 开始到 11
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
>>> range(0, 30, 5) # 步长为 5
[0, 5, 10, 15, 20, 25]
>>> range(0, 10, 3) # 步长为 3
[0, 3, 6, 9]
>>> range(0, -10, -1) # 负数
[0, -1, -2, -3, -4, -5, -6, -7, -8, -9]
>>> range(0)
[]
>>> range(1, 0)
[]
super(type[, object-or-type])
简单地说就是为了安全地继承.记住怎么用的就行了.没必要深究.
#!/usr/bin/python
# -*- coding: UTF-8 -*-
class A(object): # Python2.x 记得继承 object
def add(self, x):
y = x+1
print(y)
class B(A):
def add(self, x):
super(B, self).add(x)
b = B()
b.add(2) # 3
print('name: "%s"' % props['name'],fp) //把字符串写入文件fp
random用法
random.choice(sequence)
random.choice 选中一个
random.sample(sequence,k=) 选中多个
import random
path = "/home/train/disk/data/yulan_park_expand"
random.choices([x for x in os.listdir(path)
if os.path.isfile(os.path.join(path, x))],k=2000)
shell 工具
from shutil import copyfile
copyfile(src, dst)
参数解析
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('num1',type=int,help="img numbers to random")
parser.add_argument('num2',type=int,help="img numbers to random")
args = parser.parse_args()
命令行参数不带'-'开头的,就是类似于占位符,按顺序赋值. 比如python xxx.py 1 2则args.num1=1,args.num2=2. python xxx.py 2 1则args.num1=2,args.num2=1.
def arg_parse():
parser = argparse.ArgumentParser()
parser.add_argument('-d','--dir',type=str,default='./data',required='True',help='dir store images/label file')
parser.add_argument('-o','--output',type=str,default='./outdata.tfrecord',required='True',help='output tfrecord file name')
args = parser.parse_args()
return args
-d --dir说明命令行上传参用法.
type说明参数数据类型
default说明默认值
required说明是否为必选参数
help是参数的说明
类名直接调用
之前在pytorch和keras中经常发现一个类model被直接调用,发现很有意思。于是就去看了看pytorch中nn.Module的源码,发现是定义了__call__(self)函数再去调用forward()函数。举个例子如下:
import math
class Pow(object):
def __init__(self,n=2):
self.n=n
super(Pow,self).__init__()
def forward(self,x):
return math.pow(x,self.n)
def __call__(self,x):
return self.forward(x)
l=Pow(2)
y=l(10)
print(y) #输出结果是100
l=Pow(3)
y=l(10)
print(y) #输出结果是1000
os模块
os.walk
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import os
for root, dirs, files in os.walk(".", topdown=False):
for name in files:
print(os.path.join(root, name))
for name in dirs:
print(os.path.join(root, name))
#!/usr/bin/env python与#!/usr/bin/python的区别
脚本语言的第一行,目的就是指出,你想要你的这个文件中的代码用什么可执行程序去运行它,就这么简单
同时对2个list做相同的乱序操作
import random
a = ['a', 'b', 'c']
b = [1, 2, 3]
c = list(zip(a, b))
random.shuffle(c)
a, b = zip(*c)
print a
print b
[OUTPUT]
['a', 'c', 'b']
[1, 3, 2]
yield用法
yield在函数中的功能类似于return,不同的是yield每次返回结果之后函数并没有退出,而是每次遇到yield关键字后返回相应结果,并保留函数当前的运行状态,等待下一次的调用。如果一个函数需要多次循环执行一个动作,并且每次执行的结果都是需要的,这种场景很适合使用yield实现。
包含yield的函数成为一个生成器,生成器同时也是一个迭代器,支持通过next获取下一个值。
yield基本使用:
def func():
for i in range(0,3):
yield i
f = func()
print(next(f))
for i in f:
print(i)
输出
0
1
2
python基本使用-python基本用法笔记合集相关推荐
- Python学习笔记合集(总结)
Python学习笔记合集(总结) 第一天主要讲了Python基本语句(上) 注释 输出 标识符 多行语句 第二天主要讲了Python基本语句(下) 行与缩进 关键字 数据类型 第三天主要讲了impor ...
- 【KnowingAI知智】S4语音任务|知识卡片|笔记合集
KnowingAI知智-S4语音任务 本文系笔者在观看B站up主@KnowingAI知智的S4系列短视频所做的笔记合集 原视频见S4语音任务 S4E0:声音与机器 语音任务和自然语言处理相比,其更加纯 ...
- java入门笔记合集(杂乱)(2)
java入门笔记合集(杂乱)2 StringBuilder 这是一个容器,可以和String搭配起来用 package day1;import java.util.Scanner;public cla ...
- NLP论文笔记合集(持续更新)
NLP论文笔记合集(持续更新) 经典论文 参考文献 情感分析论文 关键词 综述 参考文献 非综述 参考文献 其他论文 参考文献 经典论文 2003年发表的文章1^11,NLP经典论文:NNLM 笔记 ...
- (小甲鱼python)集合笔记合集一 集合(上)总结 集合的简单用法 集合的各种方法合集:子、交、并、补、差、对称差集、超集
一.基础复习 集合与字典区别 集合中所有元素都是独一无二的,并且也是无序的. 集合具有唯一性.无序性.有限性 >>> type({}) #字典 <class 'dict'> ...
- python在windows的开发环境_Python合集之Python开发环境在Windows系统里面搭建
在上一个合集里面我们了解到了Python的基础信息及学习了Python对我们有什么用处,那么今天我们来了解一下,Python的开发环境该如何搭建.(注:Python的开发环境可以在Windows.MA ...
- python画心形代码大全_Python代码合集看点 机器人算法、自动导航算法算法大全...
导读:本文包含机器人算法.自动导航算法的Python代码合集.其主要特点有以下三点:选择了在实践中广泛应用的算法:依赖最少.容易阅读,容易理解每个算法的基本思想.希望阅读本文后能对你有所帮助.文章来源 ...
- 【Python】使用you-get下载bilibili视频合集
文章目录 1. `you-get` 说明 2. `you-get` 安装 3. `you-get` 使用 (1)查看视频源信息 `--info/-i` 和下载视频 (2)下载其他内容 (3)下载视频合 ...
- python字符串操作入门十八讲——合集一
字符串操作十八讲合集 导读
最新文章
- python number函数_Python3 数据类型-Number
- Shell脚本攻略01-简介/终端打印
- 中国移动、联通、电信、第三方平台IDC市场机房布局之争
- [c#]RabbitMQ的简单使用
- 使用cmake重写live555工程-附源码和视频教程
- Tomcat的Session管理(三)
- 爱情六十三课,定个开放日
- 【读书笔记】摘自Google开源项目风格指南-C++风格指南
- 例题:最高响应比优先调度算法
- Echarts实现双y轴(不同刻度)
- 激光雷达电力巡基于机载激光雷达技术的输电线路树障普查及预警
- 每日吃核桃桂圆红枣可延缓衰老
- 揭秘摄像头黑产链:暴露在外的80端口
- java并发三大特性--有序性、可见性、原子性
- 准确率、精确率、召回率、F1-measure简单总结
- 一个小白的转行自学Python的经历
- Scrapy-Splash爬取淘宝排行榜(二)
- 纵向 及纵向一体化简介
- pymysql mysql 1064_python使用pymysql操作MySQL错误代码1054和1064处理
- 局域网SDN技术硬核内幕 - 前传 突破多核的瓶颈——虚拟化
热门文章
- lucene倒排索引瘦身的一些实验——merge的本质是减少cfx文件 变为pos和doc;存储term vector多了tvx和tvd文件有337M...
- BDB c++例子,从源码编译到运行
- Nginx 配置https 自动续期
- electron node 版本不匹配的解决细节
- Requests方法 -- 关联用例执行
- 读Kafka Consumer源码
- 接口中定义变量必须为public static final的原因
- Contest2071 - 湖南多校对抗赛(2015.03.28)
- nginx实现请求的负载均衡 + keepalived实现nginx的高可用
- 奇偶交错排列(DFS)