restructure cp-version

This commit is contained in:
ville rantanen
2018-03-10 18:12:12 +02:00
parent 953fa35806
commit 52912ee293

View File

@@ -1,6 +1,7 @@
#!/usr/bin/env python #!/usr/bin/env python
import os, argparse import os, argparse
from shutil import copyfile from shutil import copyfile
from datetime import datetime
def get_options(): def get_options():
parser = argparse.ArgumentParser( parser = argparse.ArgumentParser(
@@ -10,16 +11,21 @@ def get_options():
help = "Move file instead of copying", help = "Move file instead of copying",
default = False default = False
) )
parser.add_argument('-d', action = "store_true", dest = "date",
help = "Use file date+time as version number",
default = False
)
parser.add_argument(action = "store", dest = "file") parser.add_argument(action = "store", dest = "file")
return parser.parse_args() return parser.parse_args()
def file_versionize(full_path, move = False): def get_version_name(full_path):
""" Move file to versioned with integer """ """ Move file to versioned with integer """
file_dir = os.path.dirname(full_path) file_dir = os.path.dirname(full_path)
file_name = os.path.basename(full_path) file_name = os.path.basename(full_path)
basename, extension = os.path.splitext(file_name) basename, extension = os.path.splitext(file_name)
version = 1 version = 1
while True: while True:
new_name = os.path.join( new_name = os.path.join(
file_dir, file_dir,
@@ -33,16 +39,43 @@ def file_versionize(full_path, move = False):
version += 1 version += 1
else: else:
break break
print("%s -> %s"%( return new_name
full_path,
new_name
)) def get_date_name(full_path):
if move: """ Move file to versioned with integer """
os.rename(full_path, new_name) file_dir = os.path.dirname(full_path)
else: file_name = os.path.basename(full_path)
copyfile(full_path, new_name) basename, extension = os.path.splitext(file_name)
file_time = os.stat(full_path).st_mtime
time_formatted = datetime.fromtimestamp(
file_time
).strftime("%Y%m%d_%H%M%S")
new_name = os.path.join(
file_dir,
"%s.%s%s"%(
basename,
time_formatted,
extension
)
)
return new_name
if __name__ == "__main__": if __name__ == "__main__":
opts = get_options() opts = get_options()
file_versionize(opts.file, opts.move) if os.path.isdir(opts.file):
raise ValueError("Can not handle directories")
if opts.date:
new_name = get_date_name(opts.file)
else:
new_name = get_version_name(opts.file)
print("%s -> %s"%(
opts.file,
new_name
))
if opts.move:
os.rename(opts.file, new_name)
else:
copyfile(opts.file, new_name)