sys.stderr.write(message + '\n')
sys.exit(1)
-header = """#csv2lyx created this file
-\lyxformat 276
+header = """#csv2lyx created this file. For more info see http://www.lyx.org/
+\\lyxformat 413
\\begin_document
\\begin_header
\\textclass article
+\\use_default_options true
+\\maintain_unincluded_children false
+\\language english
+\\language_package default
\\inputencoding auto
+\\fontencoding global
\\font_roman default
\\font_sans default
\\font_typewriter default
\\font_default_family default
+\\use_non_tex_fonts false
\\font_sc false
\\font_osf false
\\font_sf_scale 100
\\font_tt_scale 100
+
\\graphics default
+\\default_output_format default
+\\output_sync 0
+\\bibtex_command default
+\\index_command default
\\paperfontsize default
+\\use_hyperref false
\\papersize default
\\use_geometry false
\\use_amsmath 1
-\\use_esint 0
+\\use_esint 1
+\\use_mhchem 1
+\\use_mathdots 1
\\cite_engine basic
\\use_bibtopic false
+\\use_indices false
\\paperorientation portrait
+\\suppress_date false
+\\use_refstyle 1
+\\index Index
+\\shortcut idx
+\\color #008000
+\\end_index
\\secnumdepth 3
\\tocdepth 3
\\paragraph_separation indent
-\\defskip medskip
+\\paragraph_indentation default
+\\quotes_language english
\\papercolumns 1
\\papersides 1
\\paperpagestyle default
\\tracking_changes false
\\output_changes false
+\\html_math_output 0
+\\html_css_as_file 0
+\\html_be_strict false
\\end_header
\\begin_body
\\begin_layout Standard
-\\align left
\\begin_inset Tabular
<lyxtabular version="3" rows="%d" columns="%d">
-<features>
+<features tabularvalignment="middle">
"""
cell = """<cell alignment="left" valignment="top" usebox="none">
\\begin_inset Text
-\\begin_layout Standard
+\\begin_layout Plain Layout
%s
\\end_layout
"""
parser = optparse.OptionParser(**args)
-parser.set_defaults(excel='', column_sep='')
-parser.add_option("-e", "--excel", metavar="CHAR",
- help="""CHAR corresponds to a CSV type:
+parser.set_defaults(excel ='', column_sep = '')
+parser.add_option("-e", "--excel", metavar ="CHAR",
+ help = """CHAR corresponds to a CSV type:
'e': Excel-generated CSV file
't': Excel-generated TAB-delimited CSV file""")
-parser.add_option("-s", "--separator", dest="column_sep",
- help= """column separator
+parser.add_option("-s", "--separator", dest = "column_sep",
+ help = """column separator
't' means Tab""")
group = optparse.OptionGroup(parser, "Remarks", """If your CSV file contains special characters (e. g. umlauts,
if len(args) == 1:
infile = args[0]
fout = sys.stdout
-elif len(args) ==2:
+elif len(args) == 2:
infile = args[0]
fout = open(args[1], 'w')
else:
if options.excel not in dialects:
parser.print_help()
sys.exit(1)
-dialect= dialects[options.excel]
+dialect = dialects[options.excel]
# Set Tab, if necessary
if options.column_sep == 't':
options.column_sep = "\t"
# when no special column separator is given, try to detect it:
-if options.column_sep or dialect :
- reader = csv.reader(open(infile, "rb"), dialect= dialect, delimiter=options.column_sep)
+if options.column_sep and dialect :
+ reader = csv.reader(open(infile, "rb"), dialect = dialect, delimiter = options.column_sep)
else:
guesser = csv.Sniffer()
input_file = "".join(open(infile,'rb').readlines())
try:
dialect = guesser.sniff(input_file)
- reader = csv.reader(open(infile, "rb"), dialect= dialect)
+ reader = csv.reader(open(infile, "rb"), dialect = dialect)
except:
- reader = csv.reader(open(infile, "rb"), dialect= dialect, delimiter=',')
+ # older versions (python < 2.5) of csv have problems (bugs)
+ # that is why we try harder to get a result, this should work on most cases
+ # as it assumes that the separator is a comma (the c in csv :-) )
+ try:
+ reader = csv.reader(open(infile, "rb"), dialect = dialect, delimiter = ',')
+ except:
+ reader = csv.reader(open(infile, "rb"), delimiter = ',')
# read input
num_cols = 1 # max columns