У меня есть следующий код, в котором я получаю 3 имени файла, а также жесткий код названия заголовка.Я хочу изменить их все 4 переменные на аргументы, чтобы при запуске программы я мог дать имена и заголовок.
Мне нужен 1 из этих файлов, необходимых для ввода в оболочке, но два других необязательных аргумента и янужен -title "New Title"
необязательный аргумент для изменения старого заголовка (в противном случае это значение по умолчанию).Может ли кто-нибудь помочь мне изменить мой код или дать предложения?
Я попытался написать код следующим образом, но я не уверен, как следует изменять код Python, когда два из этих файлов не вводятся, поскольку они являются необязательными.Прямо сейчас, когда я не даю все 3 файла в качестве аргумента, выдает ошибку, что файл отсутствует. Я сам исправил опцию Заголовок в новом коде ниже
parser = argparse.ArgumentParser()
parser.add_argument('File1', help="Enter the file name to graph it")
parser.add_argument('File2', nargs='?', help="Enter the second file to graph both together")
parser.add_argument('File3', nargs='?', help="Enter the second file to graph all together")
parser.add_argument('-title',nargs='?', help="Overwrites the current title")
args=parser.parse_args()
file1 = args.File1
if args.File2:
file2=args.File2
if args.File3:
file3=args.File3
if args.title:
plt.title("\n".join(wrap(args.title)), size = 12)
else:
plt.title("\n".join(wrap("Performance for "+file1+' & '+file2 +' & '+file3)), size = 12)
Ниже приведен текущий рабочий код с 3 необходимыми файлами.Я пытаюсь изменить, чтобы он работал только с одним файлом, если другие 2 необязательные не введены.
from matplotlib import pyplot as plt
import numpy as np
from textwrap import wrap
import csv
import sys
import argparse #for optional arguments
parser = argparse.ArgumentParser()
parser.add_argument('File1', help="Enter the file name to graph it")
parser.add_argument('File2', nargs='?', help="Enter the second file to graph both together")
parser.add_argument('File3', nargs='?', help="Enter the second file to graph all together")
parser.add_argument('-title',nargs='?', help="Overwrites the current title")
args=parser.parse_args()
file1 = args.File1
if args.File2:
file2=args.File2
if args.File3:
file3=args.File3
if args.title:
plt.title("\n".join(wrap(args.title)), size = 12)
else:
plt.title("\n".join(wrap("Performance for "+file1+' & '+file2 +' & '+file3)), size = 12)
#Opens the sorted hostnum.csv file and reads it; replaces the quotation marks.
Dict = {}
csv_file = []
csv_file.append("placeholder")
with open('hostnum.csv', 'rtU') as host:
for line in host.readlines():
line = line.replace('"', '')
line = line.strip('\n')
rank, value = line.split("\t")
Dict[value] = rank
csv_file.append(value)
#Opens the file and reads it
file_1 = []
with open(file1, 'r') as f:
csvreader = csv.reader(f, delimiter='\t')
for line in csvreader:
file_1.append([Dict[line [2]], line[9]])
file_2 = []
with open(file2, 'r') as f:
csvreader = csv.reader(f, delimiter='\t')
for line in csvreader:
file_2.append([Dict[line [2]], line[9]])
file_3 = []
with open(file3, 'r') as f:
csvreader = csv.reader(f, delimiter='\t')
for line in csvreader:
file_3.append([Dict[line [2]], line[9]])
#scatters (x,y,size_of_dots, color, label)
plt.scatter([int(item[0]) for item in file_1], [int(item[1]) for item in file_1], s=4, c='b', label=file1)
plt.scatter([int(item[0]) for item in file_2], [int(item[1]) for item in file_2], s=4, c='r', label=file2)
plt.scatter([int(item[0]) for item in file_3], [int(item[1]) for item in file_3], s=4, c='g', label=file3)
#indicates the label names at the given spot (if want to change size: prop={'size':8})
plt.legend(loc='upper right', shadow=True, edgecolor = 'grey')
#Creates grid for x-y axises
#plt.grid(True, linewidth = 0.25)
#x-y labels for the graph
plt.xlabel("Node Names", fontsize = 12)
plt.ylabel("Run Times", fontsize = 12)
#ticks - x and y axisses' data format (change both ::? values in order to change the frequency)
#size is the font size; (start, end_value, frequency)
plt.xticks(np.arange(1,len(csv_file))[::5], [item[0:5] for item in csv_file[1::5]], rotation=90, size=8)
plt.yticks(np.arange(0,11000,1000), size=8)
#Saves a PNG file of the current graph to the folder and updates it every time
#(nameOfimage, dpi=(sizeOfimage),Keeps_Labels_From_Disappearing)
plt.savefig('./test.png', dpi=(250), bbox_inches='tight')
# Not to cut-off bottom labels(manually) - enlarges bottom
plt.gcf().subplots_adjust(bottom=0.23)
plt.show()
РЕДАКТИРОВАТЬ
from matplotlib import pyplot as plt
import numpy as np
from textwrap import wrap
import csv
import argparse # for optional arguments
parser = argparse.ArgumentParser()
#Argument |
#('arg_name', nargs='?' means optional arg., help="Help message when we run 'python name.py -h'")
parser.add_argument('File1', help="Enter the file name to graph it")
parser.add_argument('File2', nargs='?', help="Enter the second file to graph both together")
parser.add_argument('File3', nargs='?', help="Enter the second file to graph all together")
parser.add_argument('-title',nargs='?', help="Overwrites the current title")
args=parser.parse_args()
# Creates wrapped title for the graph using title arg.
if args.title:
plt.title("\n".join(wrap(args.title)), size = 12)
else:
plt.title("\n".join(wrap("Performance for "+file1+' & '+file2 +' & '+file3)), size = 12)
Dict = {}
csv_file = []
csv_file.append("placeholder")
with open('hostnum.csv', 'rtU') as host:
for line in host.readlines():
line = line.replace('"', '')
line = line.strip('\n')
rank, value = line.split("\t")
Dict[value] = rank
csv_file.append(value)
# Opens the file and reads it
# Scatters (x,y,size_of_dots, color, label)
file1 = args.File1
file_1 = []
with open(file1, 'r') as f:
csvreader = csv.reader(f, delimiter='\t')
for line in csvreader:
file_1.append([Dict[line [2]], line[9]])
plt.scatter([int(item[0]) for item in file_1], [int(item[1]) for item in file_1], s=4, c='b', label=file1)
if args.File2:
file2=args.File2
file_2 = []
with open(file2, 'r') as f:
csvreader = csv.reader(f, delimiter='\t')
for line in csvreader:
file_2.append([Dict[line [2]], line[9]])
plt.scatter([int(item[0]) for item in file_2], [int(item[1]) for item in file_2], s=4, c='r', label=file2)
if args.File3:
file3=args.File3
file_3 = []
with open(file3, 'r') as f:
csvreader = csv.reader(f, delimiter='\t')
for line in csvreader:
file_3.append([Dict[line [2]], line[9]])
plt.scatter([int(item[0]) for item in file_3], [int(item[1]) for item in file_3], s=4, c='g', label=file3)
# Indicates the label names at the given spot (if want to change size: prop={'size':8})
plt.legend(loc='upper right', shadow=True, edgecolor = 'grey')
# Creates grid for x-y axises
# plt.grid(True, linewidth = 0.25)
# x-y labels for the graph
plt.xlabel("Node Names", fontsize = 12)
plt.ylabel("Run Times", fontsize = 12)
# ticks - x and y axisses' data format (change both ::? values in order to change the frequency)
# size is the font size; (start, end_value, frequency)
plt.xticks(np.arange(1,len(csv_file))[::5], [item[0:5] for item in csv_file[1::5]], rotation=90, size=8)
plt.yticks(np.arange(0,11000,1000), size=8)
# Saves a PNG file of the current graph to the folder and updates it every time
# (nameOfimage, dpi=(sizeOfimage),Keeps_Labels_From_Disappearing)
plt.savefig('./test.png', dpi=(250), bbox_inches='tight')
# Not to cut-off bottom labels(manually) - enlarges bottom
plt.gcf().subplots_adjust(bottom=0.23)
plt.show()