Python XML เป็น JSON

Python Xml Json



Extensible Markup Language (XML) และ JavaScript Object Notation (JSON) เป็นรูปแบบข้อมูลที่มีชื่อเสียงสองรูปแบบสำหรับการจัดเก็บข้อมูล ทั้ง JSON และ XML ช่วยให้เราสามารถจัดเก็บข้อมูลในลักษณะที่มนุษย์และเครื่องจักรสามารถอ่านได้ ในการเริ่มต้น JSON เป็นโครงสร้างข้อมูลประเภทหนึ่งที่ใช้เป็นหลักในการแลกเปลี่ยนข้อมูลระหว่างเซิร์ฟเวอร์และแอปพลิเคชันซอฟต์แวร์ เก็บข้อมูลเป็นคู่คีย์-ค่า JSON สร้างออบเจ็กต์ของข้อมูลที่แยกคู่คีย์-ค่าตามโคลอน (:) และคู่คีย์-ค่าที่สมบูรณ์หนึ่งคู่ที่คั่นด้วยคู่อื่นตามเครื่องหมายจุลภาค







นอกจากนี้ XML เป็นภาษามาร์กอัปประเภท HTML ที่ใช้ในการจัดเก็บข้อมูลด้วย แต่ XML ไม่ได้จัดเตรียมแท็กที่กำหนดไว้ล่วงหน้าใดๆ เราสามารถสร้างแท็กของเราเองและจัดเก็บข้อมูลได้ ดังที่เราได้กล่าวไปแล้ว ทั้ง JSON และ XML ใช้เพื่อแลกเปลี่ยนข้อมูลระหว่างเซิร์ฟเวอร์และแอปพลิเคชันซอฟต์แวร์ อย่างไรก็ตาม รูปแบบข้อมูลทั้งสองแตกต่างกันบ้าง JSON เป็นรูปแบบการจัดเก็บข้อมูลประเภทอ็อบเจ็กต์ ในขณะที่ XML ไม่มีประเภท ไฟล์ XML เก็บข้อมูลในรูปแบบสตริงและหนักกว่าไฟล์ JSON เท่านั้น ในขณะที่ไฟล์ JSON สามารถเก็บสตริง อาร์เรย์ ตัวเลข ตัวเลขทศนิยม และบูลีน



บทความนี้อธิบายการแปลง XML เป็น JSON โดยใช้ Python โมดูล Python xmltodict ใช้เพื่อแปลงรูปแบบ XML เป็นรูปแบบ JSON



การติดตั้งโมดูล xmltodict

ก่อนเริ่มแปลง XML เป็น JSON เราจำเป็นต้องติดตั้งโมดูล xmltodict สามารถติดตั้งโมดูล xmltodict ได้โดยใช้แพ็คเกจดัชนี python (pip) และสามารถติดตั้งใน Python 2 และ 3 ได้ ในกรณีของ pip2 ให้รันคำสั่งต่อไปนี้เพื่อติดตั้งโมดูล xmltodict:





pip ติดตั้ง xmltodict

หากคุณกำลังใช้ pip3 ให้รันคำสั่งต่อไปนี้เพื่อติดตั้งโมดูล xmltodict:

pip3 ติดตั้ง xmltodict



ในกรณีของระบบที่ใช้ Debian ให้รันคำสั่งต่อไปนี้เพื่อติดตั้งโมดูล xmltodict:

sudo apt ติดตั้ง python-xmltodict

คำสั่งที่ให้มาข้างต้นเหมาะสำหรับ Python2 ในกรณีของเวอร์ชัน Python3 ให้รันคำสั่งต่อไปนี้:

sudo apt ติดตั้ง python3-xmltodict

การแปลง XML เป็น JSON

ตอนนี้ มาแปลงข้อมูล XML เป็นรูปแบบ JSON เราจะใช้โมดูล xmltodict และ JSON สำหรับการแปลงนี้ json เป็นโมดูล Python ในตัว ดังนั้นจึงไม่จำเป็นต้องติดตั้ง ฟังก์ชัน xmltodict.parse() แปลงข้อมูล XML เป็นพจนานุกรม Python จากนั้น ฟังก์ชัน json.dumps() จะนำอ็อบเจ็กต์พจนานุกรมที่แปลงแล้วมาเป็นอาร์กิวเมนต์และแปลงเป็นรูปแบบ JSON เพิ่มเติม นี่เป็นกระบวนการสองขั้นตอน:

ก่อนอื่นเราต้องแปลง XML เป็นวัตถุพจนานุกรม Python โดยใช้ฟังก์ชัน xmltodict.parse()

ประการที่สอง เราแปลงวัตถุพจนานุกรม Python เป็นรูปแบบ JSON โดยใช้ฟังก์ชัน json.dumps() ในฟังก์ชัน json.dumps() คุณสมบัติการเยื้องจะใช้เพื่อเพิ่มช่องว่างระหว่างข้อมูล

#นำเข้าโมดูล
นำเข้าxmltodict
นำเข้าjson
#ประกาศ xml
my_xml= '' '


1
สวนแห่งมาเร่ส์
3
อินเทอร์เน็ต
จริง


2
โกลเด้น ทิวลิป ลิตเติ้ล พาเลซ
4

อินเทอร์เน็ต
โรงยิม
ที่จอดรถ
ร้านอาหาร

เท็จ


'' '

#coverting xml เป็นพจนานุกรม Python
dict_data=xmltodictแยกวิเคราะห์(my_xml)
#ปิดบัง json
json_data=เจสันทิ้ง(dict_data,เยื้อง=2)
พิมพ์(json_data)

เอาท์พุต

ผลลัพธ์แสดงว่า XML ถูกแปลงเป็นรูปแบบ JSON สำเร็จแล้ว

ไฟล์ XML เป็นการแปลงไฟล์ JSON

ข้อมูลไฟล์ XML สามารถแปลงและบันทึกลงในไฟล์ JSON มาเปิดไฟล์ XML แปลงข้อมูล XML เป็น JSON และเก็บไว้ในไฟล์ JSON

ต่อไปนี้เป็นไฟล์ XML

#นำเข้าโมดูล
นำเข้าjson
นำเข้าxmltodict
#เปิดไฟล์ xml
กับ เปิด('hotels.xml','NS') เช่นxmlfileObj:
#การแปลงข้อมูล xml เป็นพจนานุกรม
data_dict=xmltodictแยกวิเคราะห์(xmlfileObj.อ่าน())
xmlfileObj.ปิด()
#การสร้างวัตถุ JSON โดยใช้วัตถุพจนานุกรม
jsonObj=เจสันทิ้ง(data_dict)

#storing json data ไปยังไฟล์ json
กับ เปิด('hotels.json', 'ใน') เช่นjsonfileObj:
jsonfileObj.เขียน(jsonObj)
jsonfileObj.ปิด()

เอาท์พุต

ล่าม Python ไม่แสดงข้อผิดพลาดใด ๆ หมายความว่าข้อมูล JSON ได้รับการบันทึกในไฟล์ .json เรียบร้อยแล้ว

บทสรุป

XML และ JSON เป็นรูปแบบข้อมูลยอดนิยมสองรูปแบบในการจัดเก็บข้อมูล ข้อมูล XML สามารถแปลงเป็นรูปแบบ JSON โดยใช้โมดูล xmltodict และ JSON บทความนี้อธิบายการแปลงข้อมูล XML เป็น JSON พร้อมตัวอย่าง