Google একটি পাইথন লাইব্রেরি ওপেন সোর্স করেছে যা ভিজ্যুয়ালাইজেশনের মাধ্যমে ব্যবহারের জন্য DataTable অবজেক্ট তৈরি করে। এই লাইব্রেরিটি পাইথনে একটি DataTable তৈরি করতে ব্যবহার করা যেতে পারে এবং এটিকে তিনটি ফরম্যাটে আউটপুট করতে পারে:
- JSON স্ট্রিং - আপনি যদি এমন পৃষ্ঠা হোস্ট করেন যা আপনার ডেটা ব্যবহার করে এমন ভিজ্যুয়ালাইজেশন হোস্ট করে, আপনি এটিকে পপুলেট করার জন্য একটি
DataTableকনস্ট্রাক্টরে পাস করার জন্য একটি JSON স্ট্রিং তৈরি করতে পারেন। - JSON প্রতিক্রিয়া -- আপনি যদি ভিজ্যুয়ালাইজেশন হোস্ট করে এমন পৃষ্ঠাটি হোস্ট না করেন এবং শুধুমাত্র বহিরাগত ভিজ্যুয়ালাইজেশনের জন্য একটি ডেটা উৎস হিসেবে কাজ করতে চান, তাহলে আপনি একটি সম্পূর্ণ JSON প্রতিক্রিয়া স্ট্রিং তৈরি করতে পারেন যা একটি ডেটা অনুরোধের প্রতিক্রিয়া হিসাবে ফেরত দেওয়া যেতে পারে।
- জাভাস্ক্রিপ্ট স্ট্রিং -- আপনি ডাটা টেবিলটিকে একটি স্ট্রিং হিসাবে আউটপুট করতে পারেন যা জাভাস্ক্রিপ্ট কোডের বেশ কয়েকটি লাইন নিয়ে গঠিত যা আপনার পাইথন টেবিলের ডেটা দিয়ে একটি
google.visualization.DataTableঅবজেক্ট তৈরি করবে এবং পপুলেট করবে। তারপর আপনিgoogle.visualization.DataTableঅবজেক্ট তৈরি করতে এবং পপুলেট করতে একটি ইঞ্জিনে এই জাভাস্ক্রিপ্ট চালাতে পারেন। এটি সাধারণত শুধুমাত্র ডিবাগিংয়ের জন্য ব্যবহৃত হয়।
এই নথিটি অনুমান করে যে আপনি মৌলিক পাইথন প্রোগ্রামিং বোঝেন এবং একটি ভিজ্যুয়ালাইজেশন তৈরি এবং একটি ভিজ্যুয়ালাইজেশন ব্যবহার করার জন্য প্রাথমিক ভিজ্যুয়ালাইজেশন ডকুমেন্টেশন পড়েছেন।
বিষয়বস্তু
কিভাবে লাইব্রেরি ব্যবহার করবেন
এখানে আরও বিশদে প্রাথমিক পদক্ষেপগুলি রয়েছে:
1. একটি gviz_api.DataTable অবজেক্ট তৈরি করুন
উপরের লিঙ্ক থেকে gviz_api.py লাইব্রেরি ইম্পোর্ট করুন এবং gviz_api.DataTable ক্লাস ইনস্ট্যান্টিয়েট করুন। ক্লাসটি দুটি পরামিতি নেয়: একটি টেবিল স্কিমা, যা টেবিলে ডেটার বিন্যাস বর্ণনা করবে এবং টেবিলটি পূরণ করার জন্য ঐচ্ছিক ডেটা। আপনি পরে ডেটা যোগ করতে পারেন, যদি আপনি চান, বা সম্পূর্ণরূপে ডেটা ওভাররাইট করতে পারেন, কিন্তু পৃথক সারিগুলি সরাতে পারবেন না, বা টেবিলের স্কিমা পরিষ্কার করতে পারবেন না।
2. আপনার টেবিল স্কিমা বর্ণনা করুন
টেবিল স্কিমা কন্সট্রাক্টরে পাস করা table_description প্যারামিটার দ্বারা নির্দিষ্ট করা হয়। আপনি পরে এটি পরিবর্তন করতে পারবেন না। স্কিমা টেবিলের সমস্ত কলাম বর্ণনা করে: প্রতিটি কলামের ডেটা টাইপ, আইডি এবং একটি ঐচ্ছিক লেবেল।
প্রতিটি কলাম একটি টিপল দ্বারা বর্ণনা করা হয়: ( ID [ ,data_type [ ,label [ ,custom_properties ]]])।
- আইডি - কলাম সনাক্ত করতে ব্যবহৃত একটি স্ট্রিং আইডি। স্পেস অন্তর্ভুক্ত করতে পারে। প্রতিটি কলামের আইডি অনন্য হতে হবে।
- data_type - [ ঐচ্ছিক ] সেই কলামের ডেটার পাইথন ডেটা টাইপের একটি স্ট্রিং বর্ণনাকারী৷ আপনি SingleValueToJS() পদ্ধতিতে সমর্থিত ডেটা প্রকারের একটি তালিকা খুঁজে পেতে পারেন। উদাহরণ "স্ট্রিং" এবং "বুলিয়ান" অন্তর্ভুক্ত। নির্দিষ্ট না থাকলে, ডিফল্ট "স্ট্রিং।"
- লেবেল - কলামের জন্য একটি ব্যবহারকারী-বান্ধব নাম, যা ভিজ্যুয়ালাইজেশনের অংশ হিসাবে প্রদর্শিত হতে পারে। নির্দিষ্ট না হলে, আইডি মান ব্যবহার করা হয়।
- custom_properties - কাস্টম কলাম বৈশিষ্ট্যের একটি {String:String} অভিধান।
টেবিল স্কিমা কলাম বর্ণনাকারী tuples একটি সংগ্রহ. প্রতিটি তালিকা সদস্য, অভিধান কী বা অভিধানের মান অবশ্যই অন্য সংগ্রহ বা একটি বর্ণনাকারী টুপল হতে হবে। আপনি অভিধান বা তালিকার যেকোনো সংমিশ্রণ ব্যবহার করতে পারেন, তবে প্রতিটি কী, মান বা সদস্যকে শেষ পর্যন্ত একটি বর্ণনাকারী টিপলের কাছে মূল্যায়ন করতে হবে। এখানে কিছু উদাহরণঃ।
- কলামের তালিকা: [('a', 'সংখ্যা'), ('b', 'স্ট্রিং')]
- তালিকার অভিধান: {('a', 'সংখ্যা'): [('b', 'সংখ্যা'), ('c', 'স্ট্রিং')]}
- অভিধানের অভিধান: {('a', 'সংখ্যা'): {'b': 'number', 'c': 'string'}}
- এবং তাই, বাসা বাঁধার যে কোনও স্তরের সাথে।
3. আপনার ডেটা পপুলেট করুন
টেবিলে ডেটা যোগ করতে, টেবিল স্কিমার মতো ঠিক একই কাঠামোতে ডেটা উপাদানগুলির একটি কাঠামো তৈরি করুন। সুতরাং, উদাহরণস্বরূপ, যদি আপনার স্কিমা একটি তালিকা হয় তবে ডেটা অবশ্যই একটি তালিকা হতে হবে:
- স্কিমা: [("রঙ", "স্ট্রিং"), ("আকৃতি", "স্ট্রিং")]
- ডেটা: [["নীল", "বর্গক্ষেত্র"], ["লাল", "বৃত্ত"]]
স্কিমা একটি অভিধান হলে, ডেটা অবশ্যই একটি অভিধান হতে হবে:
- স্কিমা: {("রোনের নাম", "স্ট্রিং"): [("রঙ", "স্ট্রিং"), ("আকৃতি", "স্ট্রিং")] }
- ডেটা: {"row1": ["নীল", "বর্গক্ষেত্র"], "সারি2": ["লাল", "বৃত্ত"]}
একটি টেবিল সারি সংশ্লিষ্ট ডেটা এবং স্কিমার একটি বিভাগ। উদাহরণস্বরূপ, এখানে কিভাবে দুটি কলামের একটি তালিকার স্কিমা দুটি সারি ডেটাতে প্রয়োগ করা হয়।
Schema:[(color),(shape)]
/ \
Data: [["blue", "square"], ["red", "circle"]]
Table:
Color Shape
blue square
red circleউল্লেখ্য যে এখানে অভিধান কীগুলি কলামের ডেটা মূল্যায়ন করে। আপনি কোডে AppendData() পদ্ধতির ডকুমেন্টেশনে আরও জটিল উদাহরণ পেতে পারেন। এই ধরনের জটিল নেস্টিংয়ের অনুমতি দেওয়ার উদ্দেশ্য হল আপনাকে আপনার প্রয়োজনের জন্য উপযুক্ত পাইথন ডেটা স্ট্রাকচার ব্যবহার করতে দেওয়া।
4. আপনার ডেটা আউটপুট করুন
সবচেয়ে সাধারণ আউটপুট ফরম্যাট হল JSON, তাই আপনি সম্ভবত ToJsonResponse() ফাংশন ব্যবহার করে ডেটা তৈরি করতে ফিরবেন। যাইহোক, যদি আপনি ইনপুট অনুরোধ পার্স করছেন এবং বিভিন্ন আউটপুট ফর্ম্যাট সমর্থন করছেন, আপনি কমা-বিচ্ছিন্ন মান, ট্যাব-বিচ্ছিন্ন মান এবং জাভাস্ক্রিপ্ট সহ অন্যান্য ফর্ম্যাটগুলি ফেরত দেওয়ার জন্য অন্য যেকোনো আউটপুট পদ্ধতিতে কল করতে পারেন। জাভাস্ক্রিপ্ট সাধারণত শুধুমাত্র ডিবাগিং এর জন্য ব্যবহার করা হয়। পছন্দের প্রতিক্রিয়া বিন্যাস পাওয়ার জন্য একটি অনুরোধ কীভাবে প্রক্রিয়া করতে হয় তা শিখতে একটি ডেটা উত্স বাস্তবায়ন দেখুন।
উদাহরণ ব্যবহার
বিভিন্ন আউটপুট ফরম্যাট কিভাবে ব্যবহার করতে হয় তা এখানে কিছু উদাহরণ রয়েছে।
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")