Marcelo Caressato
Marcelo Caressato

Reputation: 13

python function for loop in dictonary

I'm trying to retrieve all items from a specific key in a dictionary. The code works, but I keep receiving a None statement in the output from my function general_info. The other function specific_info works normally. Any suggestion? Thanks a lot.

countries = {
"canada": {
    'name': "Canada",
    'location': "North America",
    'currency': "Canadian Dollar",
    'capital city': "Ottawa",
    'population': "32.268.240",
    'area': "9.970.610 km2"
},
"brazil": {
    'name': "Brazil",
    'location': "South America",
    'currency': "Brazilian Real",
    'capital city': "Brasilia",
    'population': "186.404.900",
    'area': "8.514.877 km2"
},
"ukraine": {
    'name': "Ukraine",
    'location': "Europe",
    'currency': "Ukrainian Hryvnia",
    'capital city': "Kyiv",
    'population': "46.480.700",
    'area': "603.700 km2"
},
"haiti": {
    'name': "Haiti",
    'location': "North America",
    'currency': "Haitian Gourde",
    'capital city': "Port-au-Prince",
    'population': "8.527.777",
    'area': "27.750 km2"
},
"albania": {
    'name': "Albania",
    'location': "Europe",
    'currency': "Albanian Lek",
    'capital city': "Tirana",
    'population': "3.129.678",
    'area': "28.748 km2"
},
"india": {
    'name': "India",
    'location': "Asia",
    'currency': "Indian Rupee",
    'capital city': "New Delhi",
    'population': "1.103.371.000",
    'area': "3.287.263 km2"


 }
}

def general_info(c_name):
    for key, val in countries[c_name].items():
        info = print(c_name.title() + " " + key + " is " + val)
    return info

def specific_info(c_name, info):
    if c_name in countries and info in countries[c_name].keys():
        return (info.title() + " from " + c_name.title() + " is " + countries[c_name][info])


ask_country = input("Country name: ")

ask_info = input("Information requested: ")

c_name = ask_country.lower()

info = ask_info.lower()

print(general_info(c_name))
print()
print(specific_info(c_name, info))

Upvotes: 1

Views: 88

Answers (2)

akshat
akshat

Reputation: 1217

There are multiple issues in your code below:

def general_info(c_name):
    for key, val in countries[c_name].items():
        # overwrites info in every iteration
        # you are saving return value of print function
        info = print(c_name.title() + " " + key + " is " + val)  
    return info  # return only last iteration "info"

def specific_info(c_name, info):
    if c_name in countries and info in countries[c_name].keys(): # you can simply write info in countries[c_name]. No need of ".keys()" method
        return (info.title() + " from " + c_name.title() + " is " + countries[c_name][info])

To return general info you should do as follows:

def general_info(c_name):
    general_info = []
    for key, val in countries[c_name].items():
        info = (c_name.title() + " " + key + " is " + val)
        general_info.append(info )
    return general_info

Also to format strings, you should try format function. I would re-write info as:

info = "{country}: {key} is {val}".format(country=c_name.title(), key=key, val=val)

This makes you code more readable and easy to write as well.

Upvotes: 1

Cole Howard
Cole Howard

Reputation: 343

You are returning the return value of a print statement, which is always None. Just remove the print.

Upvotes: 1

Related Questions