本文整理匯總了Python中os.W_OK屬性的典型用法代碼示例。如果您正苦於以下問題:Python os.W_OK屬性的具體用法?Python os.W_OK怎麽用?Python os.W_OK使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類os
的用法示例。
在下文中一共展示了os.W_OK屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: start_download
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def start_download(self):
self.url.assert_no_error()
self.username.assert_no_error()
self.password.assert_no_error()
self.proxy.assert_no_error()
self.save_path.assert_no_error()
url = self.url.get_input()
proxy = self.proxy.get_input() or None
username = self.username.get_input()
password = self.password.get_input()
path_prefix = self.save_path.get_path()
if not os.access(path_prefix, os.W_OK):
return info("對下載文件夾沒有寫權限,請重新選擇")
if self.downloader is not None:
if not self.downloader.done:
return info("請停止後再重新點擊下載...")
self.downloader = pixiv_run(
url=url,
username=username,
password=password,
proxy=proxy,
path_prefix=path_prefix,
)
示例2: __init__
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def __init__(self, n_pop=4, **specs):
FortneyMarleyCahoyMix1.__init__(self, **specs)
# number of category
self.n_pop = int(n_pop)
# read forecaster parameter file
downloadsdir = get_downloads_dir()
filename = 'fitting_parameters.h5'
parampath = os.path.join(downloadsdir, filename)
if not os.path.exists(parampath) and os.access(downloadsdir, os.W_OK|os.X_OK):
fitting_url = 'https://raw.github.com/dsavransky/forecaster/master/fitting_parameters.h5'
self.vprint("Fetching Forecaster fitting parameters from %s to %s" % (fitting_url, parampath))
try:
urlretrieve(fitting_url, parampath)
except:
self.vprint("Error: Remote fetch failed. Fetch manually or see install instructions.")
assert os.path.exists(parampath), 'fitting_parameters.h5 must exist in /.EXOSIMS/downloads'
h5 = h5py.File(parampath, 'r')
self.all_hyper = h5['hyper_posterior'][:]
h5.close()
示例3: get_output_filename
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def get_output_filename(self, user_outputname):
'''
check that we have permissions to write to output directory
adds 'dscalar.nii' to end of outputname if not already present
'''
outputname = os.path.realpath(user_outputname)
output_dir = os.path.dirname(outputname)
if not os.access(output_dir, os.W_OK):
logger.error('Cannot write to output file {}\n'\
'The folder does not exist, or you do not have permission to write there'\
''.format(outputname))
sys.exit(1)
if not outputname.endswith('dscalar.nii'):
if not outputname.endswith('dtseries.nii'):
logger.info("Appending '.dscalar.nii' extension to outputname")
outputname = '{}.dscalar.nii'.format(outputname)
return outputname
示例4: find_config
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def find_config():
w = None
for f in search_config:
f = os.path.expanduser(f)
f = os.path.abspath(f)
d = os.path.dirname(f)
if os.path.exists(d):
if os.access(d, os.W_OK):
w = f
if os.path.exists(f):
if os.access(f, os.W_OK):
return f
elif os.access(os.path.dirname(d), os.W_OK):
os.makedirs(d)
w = f
if w is None:
print ("Cannot find suitable config path to write, create one in %s" % ' or '.join(search_config))
raise Exception("No config file")
return w
示例5: check_path_owner
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def check_path_owner(path):
# If we don't have a way to check the effective uid of this process, then
# we'll just assume that we own the directory.
if not hasattr(os, "geteuid"):
return True
previous = None
while path != previous:
if os.path.lexists(path):
# Check if path is writable by current user.
if os.geteuid() == 0:
# Special handling for root user in order to handle properly
# cases where users use sudo without -H flag.
try:
path_uid = get_path_uid(path)
except OSError:
return False
return path_uid == 0
else:
return os.access(path, os.W_OK)
else:
previous, path = path, os.path.dirname(path)
示例6: CheckOutputFile
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def CheckOutputFile(filename):
"""Check that the given file does not exist and can be opened for writing.
Args:
filename: The name of the file.
Raises:
FileExistsError: if the given filename is not found
FileNotWritableError: if the given filename is not readable.
"""
full_path = os.path.abspath(filename)
if os.path.exists(full_path):
raise FileExistsError('%s: output file exists' % filename)
elif not os.access(os.path.dirname(full_path), os.W_OK):
raise FileNotWritableError(
'%s: not writable' % os.path.dirname(full_path))
示例7: saveProject
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def saveProject(self):
"""Writes all the settings into the file"""
if not self.isLoaded():
return
# It could be another user project file without write permissions
skipProjectFile = False
if exists(self.fileName):
if not os.access(self.fileName, os.W_OK):
skipProjectFile = True
else:
if not os.access(dirname(self.fileName), os.W_OK):
skipProjectFile = True
if not skipProjectFile:
with open(self.fileName, 'w',
encoding=DEFAULT_ENCODING) as diskfile:
json.dump(self.props, diskfile, indent=4)
else:
logging.warning('Skipping updates in %s due to writing permissions',
self.fileName)
示例8: GetCacheDir
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def GetCacheDir(session):
"""Returns the path of a usable cache directory."""
cache_dir = session.GetParameter("cache_dir")
if cache_dir == None:
return cache_dir
cache_dir = os.path.expandvars(cache_dir)
if not cache_dir:
raise io_manager.IOManagerError(
"Local profile cache is not configured - "
"add a cache_dir parameter to ~/.rekallrc.")
# Cache dir may be specified relative to the home directory.
cache_dir = os.path.join(config.GetHomeDir(session), cache_dir)
if not os.access(cache_dir, os.F_OK | os.R_OK | os.W_OK | os.X_OK):
try:
os.makedirs(cache_dir)
except (IOError, OSError):
raise io_manager.IOManagerError(
"Unable to create or access cache directory %s" % cache_dir)
return cache_dir
示例9: chkdir
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def chkdir(self, path):
"""Create folder if nonexistent, check for write permission then change into directory"""
try:
os.makedirs(path)
self.show_message(_("Folder created."))
self.workdir(path)
return True
except OSError as exception:
if exception.errno == errno.EEXIST:
self.show_message(_("Directory already exists. OK."))
if os.access(path, os.W_OK):
self.workdir(path)
else:
self.show_message(_("Error: no write permission"))
self.workdir(self.stdir)
return True
elif exception.errno == errno.EACCES:
self.show_message(_("Permission denied."))
return False
else:
self.show_message(_("Invalid path"))
self.workdir(self.stdir)
return True
# Verzeichnis wechseln
示例10: setTmpDir
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def setTmpDir(self):
"""Set the tmpDir attribute to a reasonnable location for a temporary
directory"""
if os.name != 'nt':
# On unix use /tmp by default
self.tmpDir = os.environ.get("TMPDIR", "/tmp")
self.tmpDir = os.environ.get("TMP", self.tmpDir)
else:
# On Windows use the current directory
self.tmpDir = os.environ.get("TMPDIR", "")
self.tmpDir = os.environ.get("TMP", self.tmpDir)
self.tmpDir = os.environ.get("TEMP", self.tmpDir)
if not os.path.isdir(self.tmpDir):
self.tmpDir = ""
elif not os.access(self.tmpDir, os.F_OK + os.W_OK):
self.tmpDir = ""
示例11: check_msr
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def check_msr():
"""
Checks if the msr driver is loaded and if the user executing
benchexec has the read and write permissions for msr.
"""
res = {"loaded": False, "write": False, "read": False}
loaded_modules = subprocess.check_output(["lsmod"]).decode("utf-8").split("\n")
if any("msr" in module for module in loaded_modules):
res["loaded"] = True
if res["loaded"]:
cpu_dirs = os.listdir("/dev/cpu")
cpu_dirs.remove("microcode")
if all(os.access("/dev/cpu/{}/msr".format(cpu), os.R_OK) for cpu in cpu_dirs):
res["read"] = True
if all(os.access("/dev/cpu/{}/msr".format(cpu), os.W_OK) for cpu in cpu_dirs):
res["write"] = True
return res
示例12: _mkstemp_inner
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def _mkstemp_inner(dir, pre, suf, flags):
"""Code common to mkstemp, TemporaryFile, and NamedTemporaryFile."""
names = _get_candidate_names()
for seq in xrange(TMP_MAX):
name = names.next()
file = _os.path.join(dir, pre + name + suf)
try:
fd = _os.open(file, flags, 0600)
_set_cloexec(fd)
return (fd, _os.path.abspath(file))
except OSError, e:
if e.errno == _errno.EEXIST:
continue # try again
if (_os.name == 'nt' and e.errno == _errno.EACCES and
_os.path.isdir(dir) and _os.access(dir, _os.W_OK)):
# On windows, when a directory with the chosen name already
# exists, EACCES error code is returned instead of EEXIST.
continue
raise
示例13: changeFileName
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def changeFileName(self, new_name, header=None, onConsole=True, onFile=True):
"""
Change the name of the log
new_name
header (str) - A string describing the type of header information you
want with the logs passed to startLog: 'simple',
'message_only', 'no_time', <custom header>
(see startLog for more details on formatting)
onConsole (bool) - True if you want logs written to the console
onFile (bool) - True if you want the log written to the file
"""
# Get rid of tildas
new_name = os.path.expanduser(new_name)
# Check if name is okay
# Copy old log to new name
new_path, new_filename = os.path.split(new_name)
if new_path == "":
new_path = self.filePath
new_full_filename = os.path.join(new_path, new_filename)
if os.access(new_path, os.W_OK):
self.out.handlers = [] # clear old handlers
if self.onFile:
copyfile(self.fileFullName, new_full_filename)
os.remove(self.fileFullName)
self.startLog(
filePath=new_path,
fileName=new_filename,
header=header,
onConsole=onConsole,
onFile=onFile,
)
else:
log.out.warning("No permissions to write new log name")
# Make a global log object to share
示例14: check_write_access
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def check_write_access(path):
try:
if not exists(path):
os.makedirs(path)
if not os.access(path, os.W_OK):
raise IOError
return True
except (IOError, OSError):
return False
示例15: ValidateDirectoryWritable
# 需要導入模塊: import os [as 別名]
# 或者: from os import W_OK [as 別名]
def ValidateDirectoryWritable(theDir):
if not os.path.isdir(theDir):
raise argparse.ArgumentTypeError("Directory does not exist")
if os.access(theDir,os.W_OK):
return theDir
else:
raise argparse.ArgumentTypeError("Directory is not writable")