Google ने एक Python लाइब्रेरी को ओपन-सोर्स किया है, जो विज़ुअलाइज़ेशन में इस्तेमाल करने के लिए DataTable ऑब्जेक्ट बनाती है. इस लाइब्रेरी का इस्तेमाल Python में DataTable बनाने के लिए किया जा सकता है. साथ ही, इसे इन तीनों में से किसी भी फ़ॉर्मैट में तैयार किया जा सकता है:
- JSON स्ट्रिंग -- अगर ऐसा पेज होस्ट किया जा रहा है जो आपके डेटा का इस्तेमाल करने वाले विज़ुअलाइज़ेशन को होस्ट करता है, तो
DataTableकंस्ट्रक्टर में पास करने के लिए JSON स्ट्रिंग जनरेट की जा सकती है, ताकि आपके डेटा का इस्तेमाल किया जा सके. - JSON रिस्पॉन्स -- अगर विज़ुअलाइज़ेशन को होस्ट करने वाले पेज को होस्ट नहीं किया जाता और सिर्फ़ एक्सटर्नल विज़ुअलाइज़ेशन के लिए डेटा सोर्स के तौर पर काम करना है, तो JSON रिस्पॉन्स वाली पूरी स्ट्रिंग बनाई जा सकती है. यह JSON रिस्पॉन्स स्ट्रिंग, डेटा के अनुरोध के जवाब में दिखाई जा सकती है.
- JavaScript स्ट्रिंग -- डेटा टेबल को एक ऐसी स्ट्रिंग के रूप में दिखाया जा सकता है जिसमें JavaScript कोड की कई लाइनें होती हैं. यह कोड,
google.visualization.DataTableऑब्जेक्ट बनाएगा और Python टेबल के डेटा से उसे भरेगा. इसके बाद,google.visualization.DataTableऑब्जेक्ट को जनरेट करने और पॉप्युलेट करने के लिए, इस JavaScript को इंजन में चलाया जा सकता है. आम तौर पर, इसका इस्तेमाल सिर्फ़ डीबग करने के लिए किया जाता है.
इस दस्तावेज़ में यह माना गया है कि आपको Python प्रोग्रामिंग के बारे में जानकारी है. साथ ही, आपने विज़ुअलाइज़ेशन बनाने और विज़ुअलाइज़ेशन का इस्तेमाल करने के लिए, शुरुआती विज़ुअलाइज़ेशन दस्तावेज़ भी पढ़ लिए हैं.
विषय सूची
लाइब्रेरी का इस्तेमाल करने का तरीका
यहां बुनियादी चरणों के बारे में ज़्यादा जानकारी दी गई है:
1. gviz_api.DataTable
ऑब्जेक्ट बनाएं
ऊपर दिए गए लिंक से gviz_api.py लाइब्रेरी इंपोर्ट करें और gviz_api.DataTable क्लास को इंस्टैंशिएट करें. क्लास में दो पैरामीटर इस्तेमाल होते हैं:
टेबल स्कीमा, जो टेबल में मौजूद डेटा के फ़ॉर्मैट के बारे में बताएगा और
टेबल में अपने-आप जानकारी भरने के लिए वैकल्पिक डेटा होगा. अगर आप चाहें, तो बाद में डेटा जोड़ा जा सकता है या उसे पूरी तरह से ओवरराइट किया जा सकता है. हालांकि, अलग-अलग पंक्तियां या टेबल स्कीमा को हटाया नहीं जा सकता.
2. अपने टेबल स्कीमा के बारे में बताएं
टेबल स्कीमा, कंस्ट्रक्टर को पास किए गए table_description पैरामीटर से तय किया जाता है. इसे बाद में बदला नहीं जा सकता. स्कीमा में,
टेबल के सभी कॉलम के बारे में जानकारी दी जाती है: जैसे, हर कॉलम का डेटा टाइप, आईडी, और
एक वैकल्पिक लेबल.
हर कॉलम के बारे में एक टपल के ज़रिए बताया गया है: (आईडी [,data_type [,label [,custom_property]]).
- ID - स्ट्रिंग आईडी, जिसका इस्तेमाल कॉलम की पहचान करने के लिए किया जाता है. इसमें स्पेस शामिल किए जा सकते हैं. हर कॉलम का आईडी यूनीक होना चाहिए.
- data_type - [ज़रूरी नहीं] उस कॉलम में डेटा के Python डेटा टाइप का स्ट्रिंग डिस्क्रिप्टर. SingleValueToJS() तरीके में इस्तेमाल किए जा सकने वाले डेटा टाइप की सूची देखी जा सकती है. उदाहरण के लिए, "string" और "बूलियन". अगर इसके बारे में तय नहीं किया गया है, तो डिफ़ॉल्ट फ़ाइल को "स्ट्रिंग" के तौर पर इस्तेमाल किया जाता है.
- label - कॉलम के लिए उपयोगकर्ता के हिसाब से आसान नाम, जिसे विज़ुअलाइज़ेशन के हिस्से के तौर पर दिखाया जा सकता है. अगर इसके बारे में नहीं बताया गया है, तो आईडी की वैल्यू का इस्तेमाल किया जाता है.
- custom_properties - कस्टम कॉलम प्रॉपर्टी का एक {String:String} डिक्शनरी.
टेबल स्कीमा, कॉलम डिस्क्रिप्टर टुपल का एक कलेक्शन होता है. सूची के हर सदस्य, डिक्शनरी कुंजी या डिक्शनरी की वैल्यू, कोई दूसरा कलेक्शन या डिस्क्रिप्टर टपल होना चाहिए. शब्दकोशों या सूचियों के किसी भी कॉम्बिनेशन का इस्तेमाल किया जा सकता है, लेकिन हर कुंजी, वैल्यू या सदस्य को डिस्क्रिप्टर टपल के तौर पर आकलन करना चाहिए. यहां कुछ उदाहरण दिए गए हैं.
- कॉलम की सूची: [('a', 'number'), ('b', 'string')]
- Dictionary of lists: {('a', 'number'): [('b', 'number'), ('c', 'string')]}
- Dictionary of dictionaries: {('a', 'number'): {'b': 'number', 'c': 'string'}}
- और इसलिए, चाहे किसी भी लेवल पर नेस्ट किए जाने पर ऐसा ही क्यों न हो.
3. अपना डेटा भरें
टेबल में डेटा जोड़ने के लिए, उसी स्ट्रक्चर में डेटा एलिमेंट का स्ट्रक्चर बनाएं जैसा टेबल स्कीमा में है. उदाहरण के लिए, अगर आपका स्कीमा एक सूची है, तो डेटा को एक सूची होना चाहिए:
- स्कीमा: [("color", "string"), ("शेप", "स्ट्रिंग")]
- डेटा: [["blue", "square"], ["red", "circle"]]
अगर स्कीमा एक डिक्शनरी है, तो डेटा एक डिक्शनरी होना चाहिए:
- स्कीमा: {("rowname", "string"): [("color", "string"), ("shape", "string")] }
- डेटा: {"row1": ["blue", "square"], "row2": ["red", "circle"]}
टेबल की एक पंक्ति, संबंधित डेटा और स्कीमा का एक सेक्शन होती है. उदाहरण के लिए, यहां बताया गया है कि दो कॉलम की सूची के स्कीमा को, डेटा की दो पंक्तियों पर कैसे लागू किया जाता है.
Schema:[(color),(shape)]
/ \
Data: [["blue", "square"], ["red", "circle"]]
Table:
Color Shape
blue square
red circle
ध्यान दें कि यहां दी गई डिक्शनरी कुंजियां, कॉलम के डेटा का आकलन करती हैं. कोड में मौजूद अपेंड डेटा() तरीके के दस्तावेज़ में, ज़्यादा मुश्किल उदाहरण देखे जा सकते हैं. इस तरह के कॉम्प्लेक्स नेस्टिंग की अनुमति देने का मकसद, आपको अपनी ज़रूरतों के हिसाब से Python डेटा स्ट्रक्चर का इस्तेमाल करने देना है.
4. अपने डेटा का आउटपुट देना
सबसे सामान्य आउटपुट फ़ॉर्मैट JSON होता है. इसलिए, डेटा वापस पाने के लिए आपको ToJsonResponse() फ़ंक्शन का इस्तेमाल करना होगा. हालांकि, अगर इनपुट अनुरोध को पार्स किया जा रहा है और अलग-अलग आउटपुट फ़ॉर्मैट के साथ काम किया जा रहा है, तो दूसरे फ़ॉर्मैट में नतीजे दिखाने के लिए, किसी भी अन्य आउटपुट तरीके को कॉल किया जा सकता है. इनमें, कॉमा लगाकर अलग की गई वैल्यू, टैब से अलग की गई वैल्यू, और JavaScript शामिल हैं. आम तौर पर, JavaScript का इस्तेमाल सिर्फ़ डीबग करने के लिए किया जाता है. पसंदीदा रिस्पॉन्स फ़ॉर्मैट पाने के अनुरोध को प्रोसेस करने का तरीका जानने के लिए,
डेटा सोर्स को लागू करना
देखें.
इस्तेमाल करने के उदाहरण
यहां कुछ उदाहरण दिए गए हैं, जिनमें अलग-अलग तरह के आउटपुट फ़ॉर्मैट को इस्तेमाल करने का तरीका बताया गया है.
ToJSon और ToJS का उदाहरण
#!/usr/bin/python
import gviz_api
page_template = """
<html>
<script src="https://www.gstatic.com/charts/loader.js"></script>
<script>
google.charts.load('current', {packages:['table']});
google.charts.setOnLoadCallback(drawTable);
function drawTable() {
%(jscode)s
var jscode_table = new google.visualization.Table(document.getElementById('table_div_jscode'));
jscode_table.draw(jscode_data, {showRowNumber: true});
var json_table = new google.visualization.Table(document.getElementById('table_div_json'));
var json_data = new google.visualization.DataTable(%(json)s, 0.6);
json_table.draw(json_data, {showRowNumber: true});
}
</script>
<body>
<H1>Table created using ToJSCode</H1>
<div id="table_div_jscode"></div>
<H1>Table created using ToJSon</H1>
<div id="table_div_json"></div>
</body>
</html>
"""
def main():
# Creating the data
description = {"name": ("string", "Name"),
"salary": ("number", "Salary"),
"full_time": ("boolean", "Full Time Employee")}
data = [{"name": "Mike", "salary": (10000, "$10,000"), "full_time": True},
{"name": "Jim", "salary": (800, "$800"), "full_time": False},
{"name": "Alice", "salary": (12500, "$12,500"), "full_time": True},
{"name": "Bob", "salary": (7000, "$7,000"), "full_time": True}]
# Loading it into gviz_api.DataTable
data_table = gviz_api.DataTable(description)
data_table.LoadData(data)
# Create a JavaScript code string.
jscode = data_table.ToJSCode("jscode_data",
columns_order=("name", "salary", "full_time"),
order_by="salary")
# Create a JSON string.
json = data_table.ToJSon(columns_order=("name", "salary", "full_time"),
order_by="salary")
# Put the JS code and JSON string into the template.
print "Content-type: text/html"
print
print page_template % vars()
if __name__ == '__main__':
main()
ToJSonResponse का उदाहरण
JSonResponse का इस्तेमाल, रिमोट क्लाइंट किसी डेटा अनुरोध में करता है.
#!/usr/bin/python
import gviz_api
description = {"name": ("string", "Name"),
"salary": ("number", "Salary"),
"full_time": ("boolean", "Full Time Employee")}
data = [{"name": "Mike", "salary": (10000, "$10,000"), "full_time": True},
{"name": "Jim", "salary": (800, "$800"), "full_time": False},
{"name": "Alice", "salary": (12500, "$12,500"), "full_time": True},
{"name": "Bob", "salary": (7000, "$7,000"), "full_time": True}]
data_table = gviz_api.DataTable(description)
data_table.LoadData(data)
print "Content-type: text/plain"
print
print data_table.ToJSonResponse(columns_order=("name", "salary", "full_time"),
order_by="salary")