मैं अपने नाम के आधार पर एक विशेषता मान मुद्रित करने के लिए चाहते हैं, उदाहरण के लिए लेपायथन: BeautifulSoup - नाम विशेषता के आधार पर एक विशेषता मान
<META NAME="City" content="Austin">
मैं इस
soup = BeautifulSoup(f) //f is some HTML containing the above meta tag
for meta_tag in soup('meta'):
if meta_tag['name'] == 'City':
print meta_tag['content']
की तरह कुछ करना चाहता हूँ
उपरोक्त कोड KeyError: 'name'
देता है, मेरा मानना है कि ऐसा इसलिए है क्योंकि नाम BeatifulSoup द्वारा उपयोग किया जाता है, इसलिए इसे कीवर्ड तर्क के रूप में उपयोग नहीं किया जा सकता है।
>>> soup = BeautifulSoup('<META NAME="City" content="Austin">')
>>> soup.find("meta", {"name":"City"})
<meta name="City" content="Austin" />
>>> soup.find("meta", {"name":"City"})['content']
u'Austin'
एक टिप्पणी छोड़ दो अगर कुछ भी स्पष्ट नहीं है -
कैसे मैं यह कर सकता अगर मैं सभी उदाहरणों खोजना चाहते हैं, यानी अभी, soup.find ("मेटा", { "नाम": "शहर"}) ['सामग्री'] पहला परिणाम देता है, लेकिन कहें कि सूप में एक और पंक्ति थी जो <मेटा NAME = 'सिटी "सामग्री =" सैन फ्रांसिस्को "> थी। मैं कोड को कैसे संशोधित कर सकता हूं ताकि मुझे 'ऑस्टिन' और 'सैन फ्रांसिस्को' मिल सके? – overflowname
पुराना सवाल, लेकिन अगर कोई और इसके लिए देख रहा है तो यहां एक आसान समाधान है: 'soup.findAll (" मेटा ", {" नाम ":" शहर "}) ['content']'। यह सभी घटनाओं को वापस कर देगा। –