[newbie] Removing all elements that match string?
data:image/s3,"s3://crabby-images/fb1c4/fb1c4548d2bd8fea23256ca435536d0faf51fc48" alt=""
Hello, I'm only getting started with (l)xml, and was curious to know if someone had an example of how to remove all items in an XML file that match the following string: ^\t*<ele>100.25</ele>\r\n Thank you.
data:image/s3,"s3://crabby-images/7083d/7083d6278452fa2345d2002902456ea3f42386a7" alt=""
Are you looking for something like this: # ------------------------------ def remove(root, tag, text): items = root.xpath(f'.//{tag}') for item in items: if item.text == text: parent = item.getparent() parent.remove(item) return root # ------------------------------ Also look at element.iter, element.iterdescendants, etc. Dave On Fri 30 Jul 2021 11:02:59 AM PDT, Gilles wrote:
-- Dave Kuhlman http://www.davekuhlman.org
data:image/s3,"s3://crabby-images/fb1c4/fb1c4548d2bd8fea23256ca435536d0faf51fc48" alt=""
Thanks. I need to read in a GPX file, remove all occurences of the "<time>" element, regardless of what they contain, and write back the edited data: ====== import lxml.etree as et def remove(root, tag, text): items = root.xpath(f'.//{tag}') for item in items: if item.text == text: parent = item.getparent() parent.remove(item) return root tree = et.parse("input.gpx") remove(tree,"time","") #Still here print(et.tostring(tree, pretty_print=True)) with open("output.gpx", 'wb') as doc: doc.write(et.tostring(tree, pretty_print = True)) ====== I'll read up on element.iter, element.iterdescendants, etc. On 30/07/2021 21:13, Dave Kuhlman wrote:
org/mailman3/lists/lxml.python.org/ Member address: dkuhlman@davekuhlman.org
data:image/s3,"s3://crabby-images/7083d/7083d6278452fa2345d2002902456ea3f42386a7" alt=""
Are you looking for something like this: # ------------------------------ def remove(root, tag, text): items = root.xpath(f'.//{tag}') for item in items: if item.text == text: parent = item.getparent() parent.remove(item) return root # ------------------------------ Also look at element.iter, element.iterdescendants, etc. Dave On Fri 30 Jul 2021 11:02:59 AM PDT, Gilles wrote:
-- Dave Kuhlman http://www.davekuhlman.org
data:image/s3,"s3://crabby-images/fb1c4/fb1c4548d2bd8fea23256ca435536d0faf51fc48" alt=""
Thanks. I need to read in a GPX file, remove all occurences of the "<time>" element, regardless of what they contain, and write back the edited data: ====== import lxml.etree as et def remove(root, tag, text): items = root.xpath(f'.//{tag}') for item in items: if item.text == text: parent = item.getparent() parent.remove(item) return root tree = et.parse("input.gpx") remove(tree,"time","") #Still here print(et.tostring(tree, pretty_print=True)) with open("output.gpx", 'wb') as doc: doc.write(et.tostring(tree, pretty_print = True)) ====== I'll read up on element.iter, element.iterdescendants, etc. On 30/07/2021 21:13, Dave Kuhlman wrote:
org/mailman3/lists/lxml.python.org/ Member address: dkuhlman@davekuhlman.org
participants (2)
-
Dave Kuhlman
-
Gilles