Python使用中错误(持续更新.....)
1、在使用requests发送请求,响应数据转成json提示,没有可解码的json
解决办法:
这是由于,发送请求的数据,存在错误,响应出错比如404 400,所以找不到可以解码的json
示例如下:
postdata = '''{'userName':'13718651996',
'passwd':'yhlxxxx870120',
'validateCode':'abc',
'rememberMe':'true'}'''
url = 'https://secure.elong.com/passport/ajax/elongLogin'
response = Session().post(url,data=postdata)
print(response.json())
其实从图上很明显能看出问题,因为postdata是字符串类型,不是dict字典
如上图代码如果执行报如下错误:

解决办法,eval()函数将字符串,转换成字典;如下所示
postdata = '''{'userName':'13718651996',
'passwd':'yhlxxxx870120',
'validateCode':'abc',
'rememberMe':'true'}'''
url = 'https://secure.elong.com/passport/ajax/elongLogin'
request = Session().post(url,data=eval(postdata))
print(request.json())
有人可能会说,你这不是多此一举吗?把postdata直接定义成字典不就行了;你说的没错确实可以这样
postdata = {'userName':'',
'passwd':'yhlxxxx870120',
'validateCode':'abc',
'rememberMe':'true'}
url = 'https://secure.elong.com/passport/ajax/elongLogin'
request = Session().post(url,data=postdata)
print(request.json())
但是如果以下这串数据,存储在数据库中,或者excel中,读出来的时候默认就是字符串,如果读出来直接使用就会出现本文的错误,
所以哪里错了这个要知道,这是一个小细节;调试输出,发现输出跟以下是一样的,
没有错呀这是字典呢{'xxxx':'xxx'..........},但是它就是字符串。容易被忽略,所以还要使用eval(postdata)函数转成字典
{'userName':'',
'passwd':'yhlxxxx870120',
'validateCode':'abc',
'rememberMe':'true'}
正确代码:
postdata = '''{'userName':'',
'passwd':'yhlxxxx870120',
'validateCode':'abc',
'rememberMe':'true'}'''
url = 'https://secure.elong.com/passport/ajax/elongLogin'
request = Session().post(url,data=eval(postdata))
print(request.json())
------------------------------我是华丽的分隔线----------------------------------
2、join拼接路径
os.path.join拼接路径,遇到的问题,经常会把自己绕进去
str = r'd:\PHJ\Reporter\LOGS'
#报告文件路径
reporPath = os.path.join(str,'report')
isExistPath(reporPath) #创建文件夹 print(reporPath) imgPath = os.path.join(reporPath,'\\Image')
print(imgPath)
错误输出输出:
d:\PHJ\Reporter\LOGS\report
d:\Image
我们期待结果:
d:\PHJ\Reporter\LOGS\report
d:\PHJ\Reporter\LOGS\report\Image
是不是很奇怪,问题到底出在哪里,这个问题让我纠结了好久,一个不太注意的小问题。

没错,我们就是拼接的时候,多了两个返斜扛。去掉后问题解决。
3、写完项目,直接在计算机中双击py文件,报文件中引用的包找不到
项目结构,要执行run文件夹下的run.py ;报找不到run文件中引用的包

原因:双击执行的时候,不会自动向上搜索包,只会在当前文件夹及子文件夹中搜索
那么怎么办呢,把执行文件,在项目根目录下建个run.py做为执行入口,问题解决。

你可能会说了,这样做,我一些引用路径的地方不对了,那我估计是获取路径的方式是
os.getcur 获取当前路径,这样一来,你每个文件用的路径都是当前引用文件所在的路径
所以建议起个gl文件,用来存储路径。等信息。
os.path.abspath(os.path.dirname(__file__)) 用这个获取当前路径,而不要用os.getcur
否则,即使你把获取路径这些,配置到gl也就是单独一个py中,那么不同位置调用。路径也会不同。
Python使用中错误(持续更新.....)的更多相关文章
- LeetCode 题目的 Python 实现(持续更新中)
Python-LeetCode 是一个使用 Python 语言解决 LeetCode 问题的代码库,库有以下几个方面需要注意: 所有题目都是 AC 的: 按照题目顺序,每 50 个放在一个目录下,方便 ...
- LeetCode python实现题解(持续更新)
目录 LeetCode Python实现算法简介 0001 两数之和 0002 两数相加 0003 无重复字符的最长子串 0004 寻找两个有序数组的中位数 0005 最长回文子串 0006 Z字型变 ...
- Java遇到的问题、错误——持续更新
内容:dead code.关于eclipse没有js代码提示的解决 持续更新 ######################################################## dead ...
- python练习题(持续更新中。。。。。)
1.检验注册用户是否合法:需要输入用户名,校验用户名是否被注册,如已注册,提示已经注册过,没注册就可以注册:用户名不能为空:用户名长度必须在6-13位之间:最多只能输入三次. users = ['aa ...
- Python 字典 (4) 持续更新
字典一种用名字来引用值的数据结构,这种数据结构称为 映射(mapping) .字典中的键可以是数字.字符串和元组. 字典 创建和使用 创建 phonebook = {'Aaron':133000000 ...
- Python 字符串 (3) 持续更新
字符串操作 虽然字符串也是一种序列,但是它和元组一样,不可变的.当你想对它修改时,会引发异常.如 >>> strings = "Let's go">> ...
- python笔记(持续更新)
1.编译python遇到下面的编码问题: SyntaxError: Non-ASCII character '\xe9' in file E:\projects\learn.py on lin ...
- python tips(持续更新)
1. 引用上一层目录 import syssys.path.append('..')import xx 2. python json JSON是一种轻量级的数据交换格式.可以解决数据库中文存储问题,对 ...
- Python相关工具清单[持续更新]
SublimeJEDI : awesome Python autocompletion with SublimeText. Awesome Python : A curated list of awe ...
随机推荐
- 利用pentestbox打造ms17-010移动"杀器"
本文首发Freebuf,属原创奖励计划,未经许可禁止转载. 链接:http://www.freebuf.com/articles/system/132274.html 一. 前言 前段时间Shadow ...
- python 获取本机的IP
python 获取本地的IP import socket import fcntl import struct def get_ip_address(ifname): s = socket.socke ...
- html button 点击 显示倒计时秒数
如下: <html> <body> <input type="button" value="click" id="cli ...
- 自己动手在win2003系统中添加虚拟网卡
运用虚拟网卡我们可以更好地使用我们的网络,那么在win2003中该怎么操作呢?下面就为大家介绍下具体的步骤 虚拟网卡是用软件来实现虚拟的网卡,通过运用虚拟网卡我们可以更好地使用我们的网络.但是虚拟 ...
- Java8学习笔记目录
Java8学习笔记(一)--Lambda表达式 Java8学习笔记(二)--三个预定义函数接口 Java8学习笔记(三)--方法引入 Java8学习笔记(四)--接口增强 Java8学习笔记(五)-- ...
- PowerDesigner 15进行逆向工程生成数据库图表时,注释的comment的生成,解决PowerDesigner逆向工程没有列注释
使用PowerDesigner默认配置逆向工程是没有注释(name列为英文,comment列是空的),这样的不方便查看字段具体是什么意义,将注释一同导出,方便查看字段具体的意义,如下图 注释列导出步骤 ...
- Zephyr学习(五)线程和调度
前面说过zephyr支持静态和动态两种方式创建线程,这里分析动态创建的方式.应用程序通过调用k_thread_create()函数创建一个线程,实际上是调用_impl_k_thread_create( ...
- mysql导出长数字到excel避免显示为科学记数法 解决方法
经常遇到MYSQL导出长数字或纯数字字符串(如身份证.卡券号.条码.流水号等)到csv或excel文件,用excel打开会显示为科学记数法,甚至后几位转为0.这是由Excel的特性决定的:Excel显 ...
- cs231n笔记 (一) 线性分类器
Liner classifier 线性分类器用作图像分类主要有两部分组成:一个是假设函数, 它是原始图像数据到类别的映射.另一个是损失函数,该方法可转化为一个最优化问题,在最优化过程中,将通过更新假设 ...
- pandas 处理文本数据
import pandas as pd import numpy as np 常规的字符串操作 s = pd.Series(['A',"B","C"," ...