I have an XML file having the information of meeting rooms availability details. I have written application to read that xml file and store the information into a two dictionaries, one for big meeting room and other for small meeting room. My task is to update "isMeetingRoomAvailable" parameter of xml for requested pattern.
For Eg: for TowerName = tower one, meetingRoomName = ABC and for MeetingRoomTimeStamp = "2018-05-31 00:45:00", I have to update isMeetingRoomAvailable value to 1.
Below is the snippet I wrote :
from lxml import etree
root = etree.parse('test.xml')
bigRoomAvailabilityDict = {}
smallRoomAvailabilityDict = {}
towerNames = root.xpath("/root/Towers/Tower/TowerName")
MeetingRoomNames = root.xpath("/root/Towers/Tower/MeetingRooms/BigMeetingRooms/MeetingRoom/MeetingRoomName")
for tower in root.xpath("/root/Towers/Tower"):
towerName = tower.xpath("TowerName")[0].text
for lr in tower.xpath("MeetingRooms/BigMeetingRooms/MeetingRoom"):
meetingRoomName = lr.xpath("MeetingRoomName")[0].text
MeetingRoomMailId = lr.xpath("MeetingRoomMailId")[0].text
str = towerName + " " + meetingRoomName + " " + MeetingRoomMailId
for timeAvai in lr.xpath("MeetingRoomAvailabilityInfo"):
time = timeAvai.xpath("MeetingRoomTimeStamp")[0].text
isAvai = timeAvai.xpath("isMeetingRoomAvailable")[0].text
key = str + " " + time
bigRoomAvailabilityDict[key] = isAvai
for small in tower.xpath("MeetingRooms/SmallMeetingRooms/MeetingRoom"):
meetingRoomName = small.xpath("MeetingRoomName")[0].text
MeetingRoomMailId = small.xpath("MeetingRoomMailId")[0].text
str = towerName + " " + meetingRoomName + " " + MeetingRoomMailId
for timeAvai in small.xpath("MeetingRoomAvailabilityInfo"):
time = timeAvai.xpath("MeetingRoomTimeStamp")[0].text
isAvai = timeAvai.xpath("isMeetingRoomAvailable")[0].text
key = str + " " + time
smallRoomAvailabilityDict[key] = isAvai
def updateXML(towerName, meetinRoomName, timeStampVal):
roomsFromXml = root.xpath("/root/Towers/Tower/MeetingRooms/BigMeetingRooms/MeetingRoom")
# print(roomsFromXml)
for index in roomsFromXml:
roomNames = index.xpath("MeetingRoomName")
for rooms in roomNames:
# print(rooms.text)
if rooms.text == meetinRoomName:
allTimeStamps = index.xpath("MeetingRoomAvailabilityInfo")
for timeStamps in allTimeStamps:
counter = 0
for myTime in timeStamps.xpath("MeetingRoomTimeStamp"):
counter += 1
if myTime.text == timeStampVal:
break
for isAvai in timeStamps.xpath("isMeetingRoomAvailable"):
counter -= 1
if counter == 0:
isAvai.text = 1
# for key, value in bigRoomAvailabilityDict.items():
# print(key, " " , value)
XML File from link...
<root>
<Towers>
<Tower>
<TowerName>Tower one</TowerName>
<MeetingRooms>
<BigMeetingRooms>
<MeetingRoom>
<MeetingRoomName>ABC</MeetingRoomName>
<MeetingRoomMailId>mail_id_ABC</MeetingRoomMailId>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 05:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
</MeetingRoom>
<MeetingRoom>
<MeetingRoomName>JKL</MeetingRoomName>
<MeetingRoomMailId>mail_id_JKL</MeetingRoomMailId>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 05:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
</MeetingRoom>
</BigMeetingRooms>
<SmallMeetingRooms>
<MeetingRoom>
<MeetingRoomName>XYZ</MeetingRoomName>
<MeetingRoomMailId>mail_id_XYZ</MeetingRoomMailId>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 00:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 01:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 02:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 03:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:15:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:30:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 04:45:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
<MeetingRoomAvailabilityInfo>
<MeetingRoomTimeStamp>2018-05-31 05:00:00</MeetingRoomTimeStamp>
<isMeetingRoomAvailable>0</isMeetingRoomAvailable>
</MeetingRoomAvailabilityInfo>
</MeetingRoom>
</SmallMeetingRooms>
</MeetingRooms>
</Tower>
</Towers>
</root>
bigRoomAvailabilityDictandsmallRoomAvailabilityDicthave anything to do with theupdateXMLfunction (which is not called in your snippet).bigRoomAvailabilityDictandsmallRoomAvailabilityDictdictionaries as per requirement, later i have used these two dictionaries for some reference and now I have to update the xml file. I have completed reading xml file and checks logic is also done but I am stuck in updating xml file.