Select to view content in your preferred language

extracting values by using dictionary key

3738
11
Jump to solution
09-23-2014 09:51 AM
InceptionWoznicki
Deactivated User

Hi Guys,

I have text file having two columns: 1) column 1 is in the format yyyy-mm-dd and 2) column 2 is precipitation.

Objective: to extract original value of precipitation from column 2 only for month April, May, june, July, and August (4,5,6,7,8).

Procedure: Used line.split to extract only mm from yyyy-mm-dd format from column-1.

  • made dictionary to get month and precipitation value.
  • using for k,v in dct.items() and then using a if statement to extract the corresponding month precipitation value from dictionary

Problem: I can successfully print k,v (month and precipitation) from dictionary items. However, when I am using a if statement to extract the specific month's precipitation value, I am getting blank array. I was wondering can I use .append to get precipitation in (1.8,2.1,3.3) format.

 

Code:

file1 = open("test.txt","r")  Growing=[] Intermediate=[] Dormant=[]  for line in file1:     line2 = line.split()     WQ = line2[1]     month = line2[0].split("-")[1]     dct1={month:WQ}     for k,v in dct1.items():         if (k ==4 or k==5 or k==6 or k==7 or k==8):             Growing.append(dct1 )     print Growing
0 Kudos
1 Solution

Accepted Solutions
XanderBakker
Esri Esteemed Contributor

Using the attached sample file and the code below I obtained a list of precipitation values:

infile = r"D:\Xander\txt\precip.txt"

sep = "\t" # example TAB as seperator

lst_months = [4, 5, 6, 7, 8]

growing = []

header = 1

i = 0

with open(infile,"r") as f:

    for line in f:

        i += 1

        if i > header:

            line = line.strip("\n")

            data = line.split(sep)

            if len(data) == 2:

                print data

                date = data[0]

                prec = float(data[1])

                month = int(date.split("-")[1])

                if month in lst_months:

                    growing.append(prec)

print growing

Kind regards, Xander

View solution in original post

11 Replies
XanderBakker
Esri Esteemed Contributor

Using the attached sample file and the code below I obtained a list of precipitation values:

infile = r"D:\Xander\txt\precip.txt"

sep = "\t" # example TAB as seperator

lst_months = [4, 5, 6, 7, 8]

growing = []

header = 1

i = 0

with open(infile,"r") as f:

    for line in f:

        i += 1

        if i > header:

            line = line.strip("\n")

            data = line.split(sep)

            if len(data) == 2:

                print data

                date = data[0]

                prec = float(data[1])

                month = int(date.split("-")[1])

                if month in lst_months:

                    growing.append(prec)

print growing

Kind regards, Xander

InceptionWoznicki
Deactivated User

Hi Xander,

Thanks a lot for your help! I was stuck and it really helped me.Yeah, the code is working perfect. Appreciate it. Have a good one!

Sean

0 Kudos
XanderBakker
Esri Esteemed Contributor

Hi Sean, you´re welcome. Can you mark the question as answered?

Kind regards, Xander

0 Kudos
InceptionWoznicki
Deactivated User

How do I mark as answered. I looked at and found a link called as mark as helpful and did that. Is that what you wanted me to do?

0 Kudos
XanderBakker
Esri Esteemed Contributor

There should be a star "Correct Answer" that you can press next to the post that answered you question.

0 Kudos
InceptionWoznicki
Deactivated User

I think I marked as answer  now. Thank you!

0 Kudos
XanderBakker
Esri Esteemed Contributor

Yes you did. Thanks!

0 Kudos
InceptionWoznicki
Deactivated User

Hi Xander,

Just a silly question. I want to extract the corresponding date of the precip along with the precip value. For that, I added one line code: growing.append(float(date)) after growing.append(prec) in your code.

However, I got this error:"ValueError: invalid literal for float(): 2007-05-07". Do you mind to look at it?

Thank you very much for your time and help!

Sean

0 Kudos
XanderBakker
Esri Esteemed Contributor

Hi Sean,

Basically the error is telling you that the date (2007-05-07) is not a float (decimal value). The other thing is that your code will result in a list that holds a precipitation value, a date, a precipitation value, a date, etc. It would probably be more appropriate to work with a nested list like this:

date = data[0]

prec = float(data[1])

lst_date_prec = [date, prec]

month = int(date.split("-")[1])

if month in lst_months:

    growing.append(lst_date_prec)

This results i a list where each item contains a list of a precipitation value and the corresponding date. It really depends on what you want to do with the list...

Kind regards, Xander