Source code for sksurgerycore.utilities.validate_file

# coding=utf-8

"""
Various file utilities, often calling standard
functions in the os package, but throwing
nice informative Exception messages.
"""
import os


[docs]def validate_is_file(file_name): """ Check if file_name is a file. :param file_name: string containing path name :raises: TypeError if not string, ValueError if not file :returns: True """ if not file_name: raise ValueError("Empty file_name.") if not isinstance(file_name, str): raise TypeError("file_name is not a string.") if os.path.isfile(file_name): return True raise ValueError('File `' + str(file_name) + '` is not a file')
[docs]def validate_is_writable_file(file_name): """ Check if file_name is a writable file. :param file_name: string containing path name :raises: TypeError if not string, ValueError if not file :returns: True """ validate_is_file(file_name) if os.access(file_name, os.W_OK): return True raise ValueError('File `' + str(file_name) + '` is not a writeable file.')