Python os.path.exists()函数总是返回false的解决方案

如下面所示,如果我们用file的readline或readlines,在每一行后面都有一个\n回车符

直接os.path.exists(readline)时总会返回false

>>> from os.path import exists
>>> exists('dog.png')
True
>>> exists('dog.png\n')
False

使用item.strip('\n') #前面的item为我定义的变量

去掉后再传递给os.path.exists(item) 就OK了。

补充:当os.path.exists(path)的path中包含有空格时返回结果为False的解决方案

之前有个问题一直没有解决, 当路径中或文件名中存在空格时,用os.path.exists(path)判断是否存在时,都会返回False. 百思不得其解. 今天在用ipython偶到想到想了解一下到底是什么原因?

事实上,当用input()接收path输入时,path中有空格时,生成的str是不一样的. 如下:

In [4]: path = input('请将文件拖入:')

请将文件拖入:"C:\Users\xxxxx\Desktop\filename with space.txt"

In [5]: path
Out[5]: '"C:\\Users\\xxxxx\\Desktop\\filename with space.txt"'

In [6]: path1 = input('请将文件拖入:')

请将文件拖入:C:\Users\xxxxx\Desktop\filenamewithspace.txt

In [7]: path1
Out[7]: 'C:\\Users\\xxxxx\\Desktop\\filenamewithspace.txt'

In [8]: os.path.exists(path)
Out[8]: False

In [9]: os.path.exists(path1)
Out[9]: True

很明显,带有space时生了的str多了一层""字符串,故将多余的""去掉应该就可以了.以下为验证实例

In [10]: path2 = path.replace('\"', '')

In [11]: path2
Out[11]: 'C:\\Users\\xxxxx\\Desktop\\filename with space.txt'

In [12]: os.path.exists(path2)
Out[12]: True

当前读取手机存储空间的文件时,当手机root目录中存在还中文或带空格的文件/文件夹时(如下图),就会出错.

一般这时为了要读出这些文件夹,一般的操作为:

In [23]: cmd = 'adb shell ls /sdcard/'

In [24]: file_list = os.popen(cmd).readlines()
---------------------------------------------------------------------------
UnicodeDecodeError            Traceback (most recent call last)
<ipython-input-24-b7ae01065f81> in <module>
----> 1 file_list = os.popen(cmd).readlines()

UnicodeDecodeError: 'gbk' codec can't decode byte 0xae in position 10: illegal multibyte sequence

一般会报以上的错误或是不报错,但是中文文件/文件名可能为乱码,从以下的help(os.popen)可以了解后,os.popen()也是不能设置encode方式的,无解哈.

In [25]: help(os.open)
Help on built-in function open in module nt:

open(path, flags, mode=511, *, dir_fd=None)
  Open a file for low level IO. Returns a file descriptor (integer).

  If dir_fd is not None, it should be a file descriptor open to a directory,
   and path should be relative; path will then be relative to that directory.
  dir_fd may not be implemented on your platform.
   If it is unavailable, using it will raise a NotImplementedError.

所以又回到之前写的一篇文章上,要用subprocess.run()全面替换掉os.system/os.popen,这样就可以解决这些问题了.

In [27]: cmd = 'adb shell ls /sdcard/'

In [28]: file_list = subprocess.run(cmd, capture_output=True, encoding='utf-8', shell=True).stdout.
  ...: splitlines()

In [29]: file_list[0:3]
Out[29]: ['0000', '00新文件夹', '00新文件夹 test']

故上两个困扰了很久的问题,终于找到了解决方案,开心一下

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。如有错误或未考虑完全的地方,望不吝赐教。

(0)

相关推荐

  • 详解python os.path.exists判断文件或文件夹是否存在

    os即operating system(操作系统),Python 的 os 模块封装了常见的文件和目录操作. os.path模块主要用于文件的属性获取,exists是"存在"的意思,所以顾名思义,os.path.exists()就是判断括号里的文件是否存在的意思,括号内的可以是文件路径. 举个栗子: import os #判断文件夹是否存在 dir = os.path.exists('C:\\Users\\Desktop') print('dir:', dir) #判断文件是否存在 f

  • Python中的os.path路径模块中的操作方法总结

    解析路径 路径解析依赖与os中定义的一些变量: os.sep-路径各部分之间的分隔符. os.extsep-文件名与文件扩展名之间的分隔符. os.pardir-路径中表示目录树上一级的部分. os.curdir-路径中当前目录的部分. split()函数将路径分解为两个单独的部分,并返回包含这些结果的tuple.第二个元素是路径的最后部分,地一个元素是其他部分. import os.path for path in [ '/one/two/three', '/one/two/three/',

  • 对python3中pathlib库的Path类的使用详解

    用了很久的os.path,今天发现竟然还有这么好用的库,记录下来以便使用. 1.调用库 from pathlib import 2.创建Path对象 p = Path('D:/python/1.py') print(p) #可以这么使用,相当于os.path.join() p1 = Path('D:/python') p2 = p1/'123' print(p2) 结果 D:\python\1.py D:\python\123 3.Path.cwd() 获取当前路径 path = Path.cw

  • Python os.path.exists()函数总是返回false的解决方案

    如下面所示,如果我们用file的readline或readlines,在每一行后面都有一个\n回车符 直接os.path.exists(readline)时总会返回false >>> from os.path import exists >>> exists('dog.png') True >>> exists('dog.png\n') False 使用item.strip('\n') #前面的item为我定义的变量 去掉后再传递给os.path.ex

  • Python2.7版os.path.isdir中文路径返回false的解决方法

    问题背景: 本来想写一个脚本来处理硬盘里的文件,并进行分类处理,但是发现一个问题,使用python内置os模块里的方法出现一些问题,具体的见示例. 主要使用的方法(python 2.7版本) 示例: 在电脑的D盘下建立两个文件夹,并在两个文件夹下分别建立两个文件及目录: a: D:\\test\\test.txt b: D:\测试\测试.txt 分别使用a,b路径来测试os.path的几个方法 #!/usr/bin/env python # -*- coding: utf-8 -*- impor

  • Python os模块中的isfile()和isdir()函数均返回false问题解决方法

    今天在写一个linux下自动备份指定目录下的所有目录的脚本时,遇到了一个问题,由于我是需要备份目录,所以,需要判断扫描的文件是否为目录,当我用os.path.isdir()来判断的时候,发现所有文件均返回false,刚开始以为是系统兼容性问题,进一步测试,发现用os.path.isfile(),这些文件还是返回false,这肯定就是程序写的有问题了,代码如下: #!/usr/bin/env python # a python script to auto backup a directory's

  • python 中os模块os.path.exists()的用法说明

    os即operating system(操作系统),Python 的 os 模块封装了常见的文件和目录操作. os.path模块主要用于文件的属性获取,exists是"存在"的意思,所以顾名思义,os.path.exists()就是判断括号里的文件是否存在的意思,括号内的可以是文件路径. 举个栗子: user.py为存在于当前目录的一个文件 输入代码: import os path = os.path.exists('user.py') print(path) 输出结果: True P

  • python中的split()函数和os.path.split()函数使用详解

    Python中有split()和os.path.split()两个函数: split():拆分字符串.通过指定分隔符对字符串进行切片,并返回分割后的字符串列表. os.path.split():将文件名和路径分割开. 1.split()函数 语法:str.split(str=" ",num=string.count(str))[n] 参数说明: str: 表示为分隔符,默认为空格,但是不能为空串.若字符串中没有分隔符,则把整个字符串作为列表的一个元素. num:表示分割次数.如果存在参

  • python中join与os.path.join()函数实例详解

    目录 一.join函数 (一)参数使用说明 (二)实例说明 二.os.path.join() (一)参数使用 (二)实例说明 总结 一.join函数 (一)参数使用说明 描述 Python join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串. 语法 join()方法语法: str.join(sequence) 参数 sequence -- 要连接的元素序列. 返回值 返回通过指定字符连接序列中元素后生成的新字符串. (二)实例说明 1.对序列进行操作 x = ['qingni

  • 详解python路径拼接os.path.join()函数的用法

    os.path.join()函数:连接两个或更多的路径名组件 1.如果各组件名首字母不包含'/',则函数会自动加上 demo1 import os Path1 = 'home' Path2 = 'develop' Path3 = 'code' Path10 = Path1 + Path2 + Path3 Path20 = os.path.join(Path1,Path2,Path3) print ('Path10 = ',Path10) print ('Path20 = ',Path20) 输出

  • python中os.path.join()函数实例用法

    1.说明 拼接文件路径,可以有多个参数. 2.语法 os.path.join(path1,path2,*) path1 初始路径. path2 需要拼接在其后的路径.初始路径文件夹下的文件或文件夹.可以有多个需要拼接的参数,依次拼接. 3.注意 如果拼接在后的参数中含有'\'开头的参数,将从'\'开头的参数开始,前面的参数均将失效,并且路径将从对应磁盘的根目录开始. 4.实例 >>> import os >>> path='D:\dataset' >>>

  • python os.path模块常用方法实例详解

    os.path模块主要用于文件的属性获取,在编程中经常用到,以下是该模块的几种常用方法.更多的方法可以去查看官方文档:http://docs.python.org/library/os.path.html 1.os.path.abspath(path) 返回path规范化的绝对路径. >>> os.path.abspath('test.csv') 'C:\\Python25\\test.csv' >>> os.path.abspath('c:\\test.csv') '

随机推荐