MathGroup Archive 2013

[Date Index] [Thread Index] [Author Index]

Search the Archive

Re: Data format AFTER import into Mathematica from Excel.xls worksheet

  • To: mathgroup at smc.vnet.net
  • Subject: [mg131969] Re: Data format AFTER import into Mathematica from Excel.xls worksheet
  • From: "Nicholas Kormanik" <nkormanik at gmail.com>
  • Date: Thu, 7 Nov 2013 00:27:56 -0500 (EST)
  • Delivered-to: l-mathgroup@mail-archive0.wolfram.com
  • Delivered-to: l-mathgroup@wolfram.com
  • Delivered-to: mathgroup-outx@smc.vnet.net
  • Delivered-to: mathgroup-newsendx@smc.vnet.net
  • References: <77902b5b32614c84aae4f7d130ddb644@DB3PR07MB089.eurprd07.prod.outlook.com>
  • Reply-to: <nkormanik at gmail.com>

Very clear explanation, Alexei.  Thank you so much for your effort.

Nicholas Kormanik


-----Original Message-----
From: Alexei Boulbitch [mailto:Alexei.Boulbitch at iee.lu]
Sent: Wednesday, November 06, 2013 2:14 AM
To: mathgroup at smc.vnet.net
Cc: nkormanik at gmail.com
Subject: [mg131969] Re: Data format AFTER import into Mathematica from Excel.xls
worksheet

I have a large Excel worksheet (200 columns, 4,000 rows).  Every column has
a unique and carefully chosen title/label.

I'm attempting to use it within Mathematica to create a large number of
contour plots (1,000) -- using three columns at a time, for x, y, z.

The import, I suppose, occurs.  At least it appears to have.

Here's the question:

-- Is Mathematica using my column titles, so that I can refer to them in
commands subsequent to import?

-- If not, is there any format I can put my data into to begin with so that
Mathematica will readily recognize my named columns?


I certainly wanted to be getting on with the contour plots
(SmoothDensityHistogram), but am having trouble getting my data into the
required form.

Any help appreciated.

Nicholas Kormanik
nkormanik at gmail.com

Hi, Nicholas,

The answer to your question is - yes. Mathematica imports the Excel file as
it is with all its numeric and textual elements. In the result you get a
nested list. I just prepared a small rectangular Excel table for the example
purposes with the first line consisting of the column headings: "Time", "
StartTemperature", "Temperature", "Density", " Number". The rest elements
are something else including numerical data. I just took a part of my old
table with results. That is, I guess, what you need, but much smaller. I
cannot, unfortunately show the excel file file here, since the MathGroup
only accepts plain text messages.
 
Now, my notebook is in the same directory.
This imports the Excel file called "example.xls":

lst = Import[NotebookDirectory[] <> "example.xls"] // First

The result is the list, and it is shown here:

{{"Time", " StartTemperature", "Temperature", "Density",
  " Number"}, {"18:21:35", "40,000", "39,995", "---",
  "1"}, {"11:07:13", "40,000", "39,999", "1,006553",
  "2"}, {"11:08:44", "40,000", "40,000", "1,006638",
  "3"}, {"11:09:02", "40,000", "39,999", "1,006659",
  "4"}, {"11:44:21", "40,000", "39,999", "1,007191",
  "1"}, {"11:45:51", "40,000", "39,999", "1,007164",
  "2"}, {"11:52:34", "Out of range", "Out of range", "Out of range",
  "1"}}

If there is a large list to import there are several possibility to check,
if you have, indeed, imported it or not:

a) Just check this:
Length[lst]

8
If you get anything over 0 you have, indeed, imported something.

b)Then check this:

lst[[1]]
lst // Last

{"Time", " StartTemperature", "Temperature", "Density", " Number"}

{"11:52:34", "Out of range", "Out of range", "Out of range", "1"}

You will see the first and the last elements of the list. If, say, the first
element is too long or nested or both, check this:
lst[[1, 1]]

"Time"
And so on, until you get the vision of what did you import.

c) For very long lists one can always use the short form:

Short[lst]

Here it is senseless, though, since this list is already short.


OK, so we have got the list, its first line being the line is the column
headings. You can address it as follows:


lst[[1]]

{"Time", " Set Temp.", "Temperature", "Density", " Number"}

You might wish to somehow format it. You may do it as follows:

MapAt[Style[#, 16, Bold, Blue] &, lst, {1}]

This returns the same list but the headings line will be formatted according
to your wish. Try it.

To view it in a form of a table you may use, say, Grid, or TableForm. But
this is already another subject to be discussed separately, if needed.


Now, to address the individual columns by their names I can offer a simple
function as follows:

getColumn[lst_List, columnName_String] := Module[{pos},
  pos = Position[Transpose[lst], columnName][[1, 1]];
  Transpose[lst][[pos]]
  ]
Its first argument is the list in question, and the second one is the string
- the name of the column:

getColumn[lst, "Temperature"]

{"Temperature", "39,995", "39,999", "40,000", "39,999", "39,999", \
"39,999", "Out of range"}

Have fun, Alexei


Alexei BOULBITCH, Dr., habil.
IEE S.A.
ZAE Weiergewan,
11, rue Edmond Reuter,
L-5326 Contern, LUXEMBOURG

Office phone :  +352-2454-2566
Office fax:       +352-2454-3566
mobile phone:  +49 151 52 40 66 44

e-mail: alexei.boulbitch at iee.lu





  • Prev by Date: Re: Data format AFTER import into Mathematica from Excel.xls
  • Next by Date: Re: ParametricLinePlot3D
  • Previous by thread: Re: Data format AFTER import into Mathematica from Excel.xls worksheet
  • Next by thread: Use NMinimize for MonteCarloFitting???