虽然这个问题很小,但我觉得很有必要单独拿出来强调一下。

这样在遇到类似错误的时候可以很快反应过来,进而节约了时间。

这里我拿 shelve 模块举例(shelve的作用大致就是把python变量存放到文件中去),类似的问题都可以这样变通。

首先我们创建一个种子文件seed.py:

import shelve

data = shelve.open('data.db')
data['secret'] = 'hello world'

运行后在脚本文件所在目录生成了.db文件(这些文件就是存放your 'secret'的文件)

然后我们创建test.py 文件来使用该db文件。

import shelve

data = shelve.open('data.db')
print(data['secret'])

运行后会发现 屏幕显示 'hello world' 字符串。至此,你之前存储的 'secret' 就显示出来了。

重点来了。。。。。

很多时候我们并不会这样直接运行脚本文件,更多的情况是把该文件作为脚本,在需要的时候进行调用。。

举个栗子:

假设我现在处于dir目录,我忘记了我的 'secret',我想再次调用 ../test.py 来查看,可以吗?

运行后发现:

错误提示为 键错误:没有'secret' 这个键。

但是我们知道文件里明明是有的啊,而且刚才我们运行的时候也正确显示了

很多时候我们就在这里浪费了大把时间。。。 运气好的话能搜索到类似的文章,然后就开心的解决了。运气不好的话,,,自己脑补会怎样吧

其实原因就是:当我们运行python脚本的时候,对于python脚本来说,脚本的默认当前目录 就是 你执行这条运行命令时所在的目录

例如:我现在是在dir目录执行的这个脚本,那么python脚本的当前目录就在dir目录,而不是原来的temp目录

  再细化一些,根据上述脚本,data = shelve.open('data.db') 就不是在temp目录找'data.db'了,而是在运行该脚本的dir目录下找'data.db',

  但是该目录下没有'data.db',所以会新建db文件,而新建的db文件里自然是没有'secret'的。

知道了这些,就会瞬间感到豁然开朗,一切谜团都不复存在。

于是愉快的打开dir目录,果然,发现了新的db文件:

解决方法就是:不要让python依赖于默认的当前目录,给它指明绝对路径,这样就可以随时随地查看你的 'secret' 啦!

python执行时遇到 KeyError: b'somevar' 时需要想到的的更多相关文章

  1. python自带编译器在写入文件时闪退,或者一步步执行到写入时提示8170。解决办法:

    用python黑框运行程序写入文件时闪退,或一行行运行到写入时提示8170数字. 经试验,为文件路径错误导致. with open("1.doc", "wb") ...

  2. 解决Python向MySQL数据库插入中文数据时出现乱码

    解决Python向MySQL数据库插入中文数据时出现乱码 先在MySQL命令行中输入如下语句查看结果: 只要character_set_client character_set_database ch ...

  3. Python源码文件中带有中文时,输出乱码

    Python源码文件中带有中文时,文件头应加注释: #!/usr/bin/env python # -*- coding: utf-8 -*- 第一行注释是为了告诉Linux/OS X系统,这是一个P ...

  4. 在Hive中执行DDL之类的SQL语句时遇到的一个问题

    在Hive中执行DDL之类的SQL语句时遇到的一个问题 作者:天齐 遇到的问题如下: hive> create table ehr_base(id string); FAILED: Execut ...

  5. python踩坑系列之导入包时下划红线及报错“No module named”问题

    python踩坑系列之导入包时下划红线及报错“No module named”问题 使用pycharm编写Python时,自己写了一个包(commontool),在同级另一个路径下(fileshand ...

  6. 用python调试Appium和雷电模拟器连接时出现Original error: Could not find 'adb.exe' in PATH

    用python调试Appium和雷电模拟器连接时出现Original error: Could not find 'adb.exe' in PATH 确定环境变量没错,用管理员启动Appium就不会出 ...

  7. python 执行系统命令模块比较

    python 执行系统命令模块比较 1.os.system模块 仅仅在子终端运行命令,返回状态码,0为成功,其他为失败,但是不返回执行结果 如果再命令行下执行,结果直接打印出来 >>> ...

  8. 使用python执行sql语句和外键解析

    一.下载并导入pymysql pip install pymysql && import pymysql db=pymysql.connect(host=) #如果报错host大概率因 ...

  9. Python执行机制

    1.4 Python执行机制 Python中IDLE是其自带的集成开发工具(IDE:同时拥有编辑.编译.调试.运行等多种功能的集成工具),并且它也是Python自带的编译器和解释器. 1.4.1 Py ...

随机推荐

  1. java 内存分析之方法返回值二

    package Demo; class Point { private double x, y; public Point(double x, double y) { this.x = x; this ...

  2. 【Python】Java程序员学习Python(六)— 流程控制、异常处理

    和Java语言一样,Python也有基本的流程控制,简单了解下即可. 一.流程控制的元素 条件 条件就是布尔值或者布尔值的表达式,要么是True要么是False. 代码块 在Python中,代码块不是 ...

  3. react-ssr

    为什么使用SSR 与传统 SPA(Single-Page Application - 单页应用程序)相比 服务器端渲染(SSR)的优势主要在于: 更好的 SEO,由于搜索引擎爬虫抓取工具可以直接查看完 ...

  4. 11 tensorflow在tf.while_loop循环(非一般循环)中使用操纵变量该怎么做

    代码(操纵全局变量) xiaojie=1 i=tf.constant(0,dtype=tf.int32) batch_len=tf.constant(10,dtype=tf.int32) loop_c ...

  5. fastdfs搭建和使用

    目录 前言 安装 安装插件 tracker storage 用自带的 client 进行测试 想要查看结果必须安装nginx 使用示例 引用 配置 使用 前言 参考网址 错误处理 安装 安装插件 yu ...

  6. 从.net角度分析 异步和多线程

    线程 进程 CPU目前都是多核心的,相当于一个大脑几块可以同时工作. 超线程CPU是指在一块CPU中,用虚拟方法将一个物理核心模拟成多个核心(如:一个单物理核心,模拟成二个核心,即所谓的二线程.)只有 ...

  7. 原生java调用webservice的方法,不用生成客户端代码

    原生java调用webservice的方法,不用生成客户端代码 2015年10月29日 16:46:59 阅读数:1455 <span style="font-family: Aria ...

  8. Linux 系统的磁盘分区_【all】

    磁盘的存储逻辑结构 1.主引导扇区(446+64+2) MBR(主引导记录)0磁头0磁道的第一扇区 446字节 -->存放系统的引导程序,同Windows 剩下的64字节,分区表(每个分区16字 ...

  9. 计算机中的换行符、回车符、\n、\r、\n\r 怎么区分啊?

    '\r'是回车,前者使光标到行首,(carriage return)'\n'是换行,后者使光标下移一格,(line feed) \r 是回车,return\n 是换行,newline对于换行这个动作, ...

  10. 铁乐学Python_day10_函数2

    今天书接昨天的函数继续去学习了解: 昨天说到函数的动态参数. 1.函数的[动态参数] *args 动态参数,万能参数 args接受的就是实参对应的所有剩余的位置参数,并将其放在元组( )中. def ...