Python HTML parsing with beautiful soup and filtering stop words

前端 未结 1 645
北海茫月
北海茫月 2021-01-07 04:55

I am parsing out specific information from a website into a file. Right now the program I have looks at a webpage, and find the right HTML tag and parses out the right conte

1条回答
  •  攒了一身酷
    2021-01-07 05:27

    import urllib2
    import BeautifulSoup
    import string
    
    badwords = set([
        'cup','cups',
        'clove','cloves',
        'tsp','teaspoon','teaspoons',
        'tbsp','tablespoon','tablespoons',
        'minced'
    ])
    
    def cleanIngred(s):
        # remove leading and trailing whitespace
        s = s.strip()
        # remove numbers and punctuation in the string
        s = s.strip(string.digits + string.punctuation)
        # remove unwanted words
        return ' '.join(word for word in s.split() if not word in badwords)
    
    def main():
        url = "http://allrecipes.com/Recipe/Slow-Cooker-Pork-Chops-II/Detail.aspx"
        data = urllib2.urlopen(url).read()
        bs = BeautifulSoup.BeautifulSoup(data)
    
        ingreds = bs.find('div', {'class': 'ingredients'})
        ingreds = [cleanIngred(s.getText()) for s in ingreds.findAll('li')]
    
        fname = 'PorkRecipe.txt'
        with open(fname, 'w') as outf:
            outf.write('\n'.join(ingreds))
    
    if __name__=="__main__":
        main()
    

    results in

    olive oil
    chicken broth
    garlic,
    paprika
    garlic powder
    poultry seasoning
    dried oregano
    dried basil
    thick cut boneless pork chops
    salt and pepper to taste
    

    ? I don't know why it's left the comma in it - s.strip(string.punctuation) should have taken care of that.

    0 讨论(0)
提交回复
热议问题