一.Python的包搜索路径
Python会在以下路径中搜索它想要寻找的模块:
1. 程序所在的文件夹
2. 标准库的安装路径
3. 操作系统环境变量PYTHONPATH所包含的路径
二.报错SyntaxError: Non-ASCII character '\xe5' in file /home/cwq/motion_detector/src/cwq98/src/Model/centroidtracker.py on line 12, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details
当你使用使用python3写好的python程序使用python2运行时,或者在运行你的python程序时,出现了一下错误:
SyntaxError: Non-ASCII character ‘\xe5’ in file figure4_5.py on line 22, but no encoding declared; see http://www.python.org/peps/pep-0263.html for details
这是因为程序编码有问题,只需要在你程序开始的地方加入(程序最最顶端)以下代码即可:
#!usr/bin/python
# -*- coding: utf-8 -*-
三.报错
Traceback (most recent call last):
File "/home/cwq/motion_detector/src/cwq98/src/motion_detector.py", line 9, in <module>
from Model.centroidtracker import CentroidTracker
File "/home/cwq/motion_detector/src/cwq98/src/Model/centroidtracker.py", line 5, in <module>
from scipy.spatial import distance as dist
ImportError: No module named scipy.spatial
犯错误:调用Python对象时,超出了最大递归深度
Traceback (most recent call last):异常
通常很难出现这样的错误。只能一点点排除:
1.磁盘空间满了。 比如/tmp, /var 或者是/分区满了。
2.文件读写错误,在临时目录里,某些文件被锁,无法读写导致
3.内存不足(这个可能性小),你可以将占用内存多的程序去掉
4.你是在虚拟机里运行,可能内存访问函数不能正确使用
5.有防火墙的问题
6.可能是权限的问题,比如某些程序需要超级用户的权限
7.程序本身有BUG,它预留的计算空间不够。你可以检查一下配置什么的,看看有没有设置预加载内存的配置。
通常space是指磁盘空间, memory是指内存。
#举个栗子(函数递归调用)
def f1():
print('===>f1')
f2()
def f2():
print('===>f2')
f1() #再次调用函数f1
f1()# 运行代码拉到很后面会报错:Traceback (most recent call last)
RecursionError: maximum recursion depth exceeded while calling a Python object 调用Python对象时,超出了最大递归深度。
四.def __init__(self)是用于初始化类。
1.def __init__(self),不带参数,此处借鉴另一位博主的程序做一下分析
class Game: # 定义类Game
def __init__(self): # 创建类中的函数,也叫方法
self.name = None
self.score = None def print_score(self):
print("%s score is %s" % (self.name,self.score)) s1 = Game() # 创建对象s1
s1.name = "Tom"
s1.score = 8 s1.print_score()
在此例中,__init__(self)里没有设置其他的参数,但是在本方法内部有两个属性{name,score}。它是允许定义一个空的结构的,当来新数据时再往里面添加。不过本方法在使用的时候需要事先实例化,然后再进行赋值操作,如横线处所示。
2.def __init__(self,参数),带多参数
class Game: # 定义类Game
def __init__(self, name, score): # 创建类中的函数,也叫方法
self.name = name
self.score = score def print_score(self):
print("%s score is %s" % (self.name,self.score)) s1 = Game("Tom", 8) # 创建对象s1
s1.print_score()
在此例中,__init__(self)里直接设置了其他的参数,也就是说在定义方法的时候就直接把{name,score}给设置好了。故在创建对象的时候必须同样填入属性值,如横线处所示
五.for i in enumerate(): 解析
enumerate就是枚举的意思,把元素一个个列举出来,第一个是什么,第二个是什么,所以他返回的是元素以及对应的索引。
line = [1,2,3,4,5,6,7,8,9]
for i,j in enumerate(line):
print(i,j)
#以下是输出结果
0 1
1 2
2 3
3 4
4 5
5 6
6 7
7 8
8 9
#eg2:
line = ["a","b","c","d","e"]
for i,j in enumerate(line):
print(i,j)
#output:
0 a
1 b
2 c
3 d
4 e
六.python — argparse模块,及Pycharm传递参数给argparse
argparse 模块可以编写用户友好的命令行接口。
程序定义它需要的参数,然后 argparse 将弄清如何从 sys.argv 解析出那些参数。 argparse 模块还会自动生成帮助和使用手册,并在用户给程序传入无效参数时报出错误信息。
一、argparse用法
主要有三个步骤:
创建 ArgumentParser() 对象
调用 add_argument() 方法添加参数
使用 parse_args() 解析添加的参数
示例demo如下:
以深度学习中经常出项的的演示demo为例
# 导入包
import argparse
# 创建解析器
ap = argparse.ArgumentParser()
# 添加位置参数(positional arguments)
ap.add_argument("-i", "--input", required=True,
help="path to the input folder")
ap.add_argument("-m", "--model", required=True,
help="path to the model file")
args = vars(ap.parse_args())
print(args)
print(args["input"],args["model"])
用来创建参数的对象.
七.在pycharm 虚拟环境python2.7中运行cv_bridge 报错
ibcv_bridge.so cannot open shared object file
解决办法: 在pycharm中编辑configuration, 添加
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/opt/ros/kinetic/lib