472,951 Members | 2,228 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 472,951 software developers and data experts.

CSV to Array

i have a csv file that has a number in one column and a corresponding number in the second column. i am trying to store both of these numbers in an array. i have done this before with an excel file but how would i go about doing this with a csv file since the command xlsht wont work in csv. here is my code so far to print everything but how do i store them in an array and what would be the correct way to define the array.

Expand|Select|Wrap|Line Numbers
  1. import csv
  2. reader = csv.reader(open("C:\Fahad\New\Dtap.csv", "rb"))
  3. for row in reader:
  4.     print row
  5.  
Nov 2 '07 #1
5 8809
ok i did figure out how to store it in an array but how do i store it as a number. it looks like python is just treating it like a character instead of a number.
also i want the array size to be equal to the number of columns in the csv file what would be the correct way to define that?
Nov 2 '07 #2
bartonc
6,596 Expert 4TB
ok i did figure out how to store it in an array but how do i store it as a number. it looks like python is just treating it like a character instead of a number.
also i want the array size to be equal to the number of columns in the csv file what would be the correct way to define that?
Here's a trick that I use. I hope you find it useful:
Expand|Select|Wrap|Line Numbers
  1. >>> data = ['12.2', 'hello', '7']
  2. >>> converters = (float, str, int)
  3. >>> for i, item in enumerate(data):
  4. ...     print converters[i](item)
  5. ...     
  6. 12.2
  7. hello
  8. 7
  9. >>> 
Nov 2 '07 #3
bvdet
2,851 Expert Mod 2GB
This function is useful when you do not know the types of the data items:
Expand|Select|Wrap|Line Numbers
  1. def convertType(s):
  2.         for func in (int, float, eval):
  3.             try:
  4.                 n = func(s)
  5.                 return n
  6.             except:
  7.                 pass
  8.         return s
Expand|Select|Wrap|Line Numbers
  1. >>> data = ['12.2', 'hello', '7', '[12,24,36,"goodbye"]', '12*12']
  2. >>> for item in data:
  3. ...     print convertType(item)
  4. ...     
  5. 12.2
  6. hello
  7. 7
  8. [12, 24, 36, 'goodbye']
  9. 144
  10. >>> 
Nov 2 '07 #4
bartonc
6,596 Expert 4TB
This function is useful when you do not know the types of the data items:
Expand|Select|Wrap|Line Numbers
  1. def convertType(s):
  2.         for func in (int, float, eval):
  3.             try:
  4.                 n = func(s)
  5.                 return n
  6.             except:
  7.                 pass
  8.         return s
Expand|Select|Wrap|Line Numbers
  1. >>> data = ['12.2', 'hello', '7', '[12,24,36,"goodbye"]', '12*12']
  2. >>> for item in data:
  3. ...     print convertType(item)
  4. ...     
  5. 12.2
  6. hello
  7. 7
  8. [12, 24, 36, 'goodbye']
  9. 144
  10. >>> 
Nice touch, throwing in the eval! I really like it!
Nov 2 '07 #5
bvdet
2,851 Expert Mod 2GB
Nice touch, throwing in the eval! I really like it!
I actually use this in almost every script run in SDS/2. We import data from a text file formatted like this:

#Python Script Default File
access_hole_height=1.25
access_hole_length=1.25
access_hole_radius=0.5
flange_setback_bott=6.5
flange_setback_top=6.5
flush_lower_left=0.0
flush_lower_right=0.0
flush_upper_left=0.5
flush_upper_right=0.5
prep_angle=45.0
prep_list=['Top Left', 'Bottom Left']
print_doc=No
Here's the actual code used:
Expand|Select|Wrap|Line Numbers
  1. def fdim(s):
  2.     ss = s.split('/')
  3.     return float(ss[0])/float(ss[1])
  4.  
  5. def convertType(s):
  6.         for func in (int, float, fdim, eval):
  7.             try:
  8.                 n = func(s)
  9.                 return n
  10.             except:
  11.                 pass
  12.         return s
  13.  
  14. def import_data(file_name):
  15.     patt = r'.+=.+'
  16.     try:
  17.         data = [item.strip().split('=') for item in re.findall(patt, open(file_name).read()) if not item.startswith('#')]
  18.         return dict(zip([j[0].strip() for j in data], [convertType(i[1].strip()) for i in data]))
  19.     except:
  20.         Warning("User default file import error. Reverting to auto or initial defaults...")
  21.         return None
It returns a dictionary with the values of the correct types. The 'eval()' was necessary to convert saved lists, and the 'fdim()' to convert fractions that were saved to disk as strings.
Nov 2 '07 #6

Sign in to post your reply or Sign up for a free account.

Similar topics

2
by: Brian | last post by:
I'm diddlying with a script, and found some behavior I don't understand. Take this snippet: for ($i = 0; $i <= count($m); $i++) { array_shift($m); reset($m); }
2
by: Stormkid | last post by:
Hi Group I'm trying to figure out a way that I can take two (two dimensional) arrays and avShed and shed, and subtract the matching elements in shed from avShed I've pasted the arrays blow from a...
15
by: lawrence | last post by:
I wanted to test xml_parse_into_struct() so I took the example off of www.php.net and put this code up on a site: <?php $simple = <<<END <item>
8
by: vcardillo | last post by:
Hello all, Okay, I am having some troubles. What I am doing here is dealing with an employee hierarchy that is stored in an array. It looks like this: $employees = array( "user_id" => array(...
12
by: Sam Collett | last post by:
How do I remove an item with a specified value from an array? i.e. array values 1,2,2,5,7,12,15,21 remove 2 from array would return 1,5,7,12,15,21 (12 and 21 are NOT removed, duplicates are...
8
by: Mike S. Nowostawsky | last post by:
I tried using the "toUpperCase()" property to change the value of an array entity to uppercase BUT it tells me that the property is invalid. It seems that an array is not considered an object when...
58
by: jr | last post by:
Sorry for this very dumb question, but I've clearly got a long way to go! Can someone please help me pass an array into a function. Here's a starting point. void TheMainFunc() { // Body of...
104
by: Leszek | last post by:
Hi. Is it possible in javascript to operate on an array without knowing how mamy elements it has? What i want to do is sending an array to a script, and this script should add all values from...
7
by: Jim Carlock | last post by:
Looking for suggestions on how to handle bad words that might get passed in through $_GET variables. My first thoughts included using str_replace() to strip out such content, but then one ends...
17
by: =?Utf-8?B?U2hhcm9u?= | last post by:
Hi Gurus, I need to transfer a jagged array of byte by reference to unmanaged function, The unmanaged code should changed the values of the array, and when the unmanaged function returns I need...
2
isladogs
by: isladogs | last post by:
The next Access Europe meeting will be on Wednesday 6 Sept 2023 starting at 18:00 UK time (6PM UTC+1) and finishing at about 19:15 (7.15PM) The start time is equivalent to 19:00 (7PM) in Central...
0
by: Mushico | last post by:
How to calculate date of retirement from date of birth
2
by: DJRhino | last post by:
Was curious if anyone else was having this same issue or not.... I was just Up/Down graded to windows 11 and now my access combo boxes are not acting right. With win 10 I could start typing...
2
isladogs
by: isladogs | last post by:
The next Access Europe meeting will be on Wednesday 4 Oct 2023 starting at 18:00 UK time (6PM UTC+1) and finishing at about 19:15 (7.15PM) The start time is equivalent to 19:00 (7PM) in Central...
0
by: Aliciasmith | last post by:
In an age dominated by smartphones, having a mobile app for your business is no longer an option; it's a necessity. Whether you're a startup or an established enterprise, finding the right mobile app...
4
NeoPa
by: NeoPa | last post by:
Hello everyone. I find myself stuck trying to find the VBA way to get Access to create a PDF of the currently-selected (and open) object (Form or Report). I know it can be done by selecting :...
3
NeoPa
by: NeoPa | last post by:
Introduction For this article I'll be using a very simple database which has Form (clsForm) & Report (clsReport) classes that simply handle making the calling Form invisible until the Form, or all...
1
by: Teri B | last post by:
Hi, I have created a sub-form Roles. In my course form the user selects the roles assigned to the course. 0ne-to-many. One course many roles. Then I created a report based on the Course form and...
3
by: nia12 | last post by:
Hi there, I am very new to Access so apologies if any of this is obvious/not clear. I am creating a data collection tool for health care employees to complete. It consists of a number of...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.