Source code for unravel.tabular.columns
#!/usr/bin/env python3
"""
Use ``tabular_columns`` (``cols``) from UNRAVEL to load a CSV or xlsx file and print the column(s).
Usage:
------
tabular_columns --input path/input.csv [-one-per-line] [-v]
"""
import pandas as pd
from rich import print
from rich.traceback import install
from unravel.core.help_formatter import RichArgumentParser, SuppressMetavar, SM
from unravel.core.config import Configuration
from unravel.core.utils import log_command, verbose_start_msg, verbose_end_msg
[docs]
def parse_args():
parser = RichArgumentParser(formatter_class=SuppressMetavar, add_help=False, docstring=__doc__)
reqs = parser.add_argument_group('Required arguments')
reqs.add_argument('-i', '--input', required=True, help='Path to the input CSV or xlsx file.', action=SM)
opts = parser.add_argument_group('Optional arguments')
opts.add_argument('-1', '--one-per-line', help='Print each column name on a separate line.', action='store_true', default=False)
opts.add_argument('-d', '--delimiter', help='Delimiter used in the CSV file. Default: ", "', default=', ')
general = parser.add_argument_group('General arguments')
general.add_argument('-v', '--verbose', help='Increase verbosity. Default: False', action='store_true', default=False)
return parser.parse_args()
[docs]
@log_command
def main():
install()
args = parse_args()
Configuration.verbose = args.verbose
verbose_start_msg()
# Load the CSV header
if str(args.input).endswith('.csv'):
cols = pd.read_csv(args.input, nrows=0).columns
elif str(args.input).endswith('.xlsx'):
cols = pd.read_excel(args.input, nrows=0).columns
# Print column names
if args.one_per_line:
for col in cols:
print(f'[default]{col}')
else:
print("Columns in the CSV file:")
print(f"[default]{args.delimiter}".join(cols))
verbose_end_msg()
if __name__ == '__main__':
main()