বাক্য গঠন:
পাইথনে Pydantic ডেটাক্লাসগুলি ব্যবহার করে ডেটা কীভাবে পরিচালনা করা হয় তা উন্নত করার একটি সহজ কিন্তু কার্যকর উপায় হল ক্লাস ডেকোরেটর ব্যবহার করা যার সাহায্যে আমরা মূলত আমাদের ডেটা কেমন হওয়া উচিত তার জন্য একটি মডেল তৈরি করি। এটি আমাদের ডেটাকে একটি পরিষ্কার কাঠামো দেওয়ার মতো। সুতরাং, ডেটা ক্লাস সংজ্ঞায়িত করার জন্য সিনট্যাক্স নিম্নরূপ:
ক্লাস ণশড ( বেস মডেল )
'model_name' আমরা যে মডেলটি তৈরি করতে চাই তার নাম উপস্থাপন করে এবং Pydantic থেকে 'BaseModel' একজন অভিভাবকের মতো কাজ করে যা নিশ্চিত করে যে ডেটা আমাদের সেট করা নিয়মগুলি অনুসরণ করে এবং মডেলটিকে তার ইনপুট প্যারামিটার হিসাবে প্রেরণ করা হয়। ক্লাসের ভিতরে, আমরা সংজ্ঞায়িত করি যে ডেটার প্রতিটি অংশে কী ধরনের তথ্য থাকা উচিত। এই প্রক্রিয়াটি নিশ্চিত করে যে আমরা যখন ডেটাক্লাসের একটি উদাহরণ তৈরি করি, তখন আমরা যে তথ্য প্রদান করি তা আমাদের সংজ্ঞায়িত করা সাথে মিলে যায়।
পদ্ধতি 1: Pydantic এর ডেটাক্লাসের সাথে উন্নত ডেটা হ্যান্ডলিং
কল্পনা করুন যে আমরা আমাদের সংগ্রহে থাকা বইগুলির তথ্য সংগঠিত করার জন্য একটি সহজ অ্যাপ্লিকেশন তৈরি করছি। আমরা নিশ্চিত করতে চাই যে এই উদ্দেশ্যে আমরা যে ডেটা সংগ্রহ করি তা সঠিক, সামঞ্জস্যপূর্ণ এবং সুগঠিত। এখানেই Pydantic ডেটাক্লাসগুলি প্রক্রিয়াটিকে সহজ এবং উন্নত করতে পদক্ষেপ নেয়।
উদাহরণ দিয়ে শুরু করার জন্য একটি Pydantic Dataclass সংজ্ঞায়িত করা প্রয়োজন। সুতরাং, আমরা 'বই' নামে একটি পাইড্যান্টিক ডেটাক্লাস সংজ্ঞায়িত করে শুরু করি যা বইগুলির বিবরণ উপস্থাপন করে। Pydantic-এর জন্য ডেটাক্লাস সংজ্ঞায়িত করতে, আমাদের নিশ্চিত করতে হবে যে সমস্ত Pydantic-এর প্যাকেজগুলি প্রকল্পের আগে ইনস্টল করা আছে।
থেকে pydantic আমদানি বেস মডেল
ক্লাস ডেকোরেটর ব্যবহার করে, আমরা পাইডান্টিকের বেসমডেল থেকে উত্তরাধিকারসূত্রে পাওয়া 'বুক' ক্লাস তৈরি করি। ক্লাসের ভিতরে, আমরা শিরোনাম, লেখক এবং প্রকাশ_বছরের মতো বৈশিষ্ট্যগুলি নির্দিষ্ট করি, প্রতিটি তার নিজ নিজ ডেটা প্রকারের সাথে যুক্ত।
ক্লাস বই ( বেস মডেল ) :শিরোনাম: str
লেখক: str
মুক্তির বছর: int
একটি ক্লাস মডেল তৈরি করার পরে, আমরা পাইডান্টিক ডেটাক্লাস ব্যবহার করি, 'মুভি' ডেটা পরিচালনা করতে 'বুক' ডেটাক্লাসের ক্ষমতা গ্রহণ করি:
এই বিভাগে, আমরা একজন ব্যবহারকারীকে অনুকরণ করি যে বই সম্পর্কিত বিশদ তথ্য দেয়। 'বই' ডেটাক্লাসের মডেলে শিরোনাম, লেখক এবং প্রকাশিত বছরের মতো বৈশিষ্ট্যগুলি তাদের স্বতন্ত্র ডেটাটাইপ সহ রয়েছে। সুতরাং, এই অংশে, অর্থাত্ 'ইনপুট', আমরা তাদের মানগুলি নির্দিষ্ট করি।
ইনপুট = {'শিরোনাম' : 'কষ্ট' ,
'লেখক' : 'আদম' ,
'মুক্তির বছর' : 2023
}
ইনপুটে বইয়ের মডেলের বৈশিষ্ট্য সম্পর্কে বিশদ বিবরণের পরে, আমরা এই বিবরণগুলি ব্যবহার করে প্রদত্ত ডেটা সহ একটি 'বুক' উদাহরণ তৈরি করি; এটি নিশ্চিত করার জন্য করা হয় যে Pydantic স্বয়ংক্রিয়ভাবে সংজ্ঞায়িত ডেটা স্ট্রাকচারের বিরুদ্ধে ইনপুটকে যাচাই করে। যদি কোনো অসঙ্গতি বা ভুল থাকে, যেমন একটি অ-পূর্ণসংখ্যা প্রকাশের বছর বা একটি অনুপস্থিত শিরোনাম, Pydantic দ্রুত একটি ব্যবহারকারী-বান্ধব ব্যাখ্যা সহ একটি ত্রুটি উত্থাপন করে।
চেষ্টা করুন :বই = বই ( ** ইনপুট )
ছাপা ( 'বইয়ের বিবরণ:' , বই শিরোনাম , বই লেখক , বই মুক্তির বছর )
ছাড়া ব্যতিক্রম হিসাবে এইটা:
ছাপা ( 'ত্রুটি:' , এইটা )
Pydantic ডেটাক্লাসগুলির সাথে অভিজ্ঞ উন্নত ডেটা পরিচালনার জন্য, আমরা ডেটা যাচাইকরণ এবং সামঞ্জস্যের জন্য একটি অন্তর্নির্মিত প্রক্রিয়া পাই। আমরা বিভিন্ন ডেটা পরিস্থিতি কভার করার জন্য ঐচ্ছিক ক্ষেত্র, ডিফল্ট মান এবং জটিল নেস্টেড কাঠামো অন্তর্ভুক্ত করতে পারি। এটি গ্যারান্টি দেয় যে আমাদের ডেটা সংগঠিত এবং সঠিকভাবে ফর্ম্যাট করা থাকবে।
এই ধাপটি অন্বেষণ করে যে কিভাবে Pydantic ডেটাক্লাসগুলি ঐচ্ছিক ক্ষেত্র, ডিফল্ট মান এবং নেস্টেড স্ট্রাকচারের মতো বৈশিষ্ট্যগুলির মাধ্যমে উন্নত ডেটা পরিচালনার ক্ষমতা প্রদান করে।
এখানে একটি উদাহরণ যেখানে আমরা দেখাই কিভাবে ঐচ্ছিক ক্ষেত্র এবং ডিফল্ট মান যোগ করতে হয়:
ধরুন আমরা ব্যবহারকারীদের বই সম্পর্কে অতিরিক্ত বিবরণ যেমন ধরণ এবং রানটাইম ইনপুট করার অনুমতি দিতে চাই। যাইহোক, এই বিবরণ সবসময় উপলব্ধ নাও হতে পারে. Pydantic ডেটাক্লাসের সাথে, আমরা ক্ষেত্রগুলিকে ঐচ্ছিক করে এমনকি ডিফল্ট মান সেট করে সহজেই এটি অর্জন করতে পারি।
এই উদাহরণে, 'মুভি' ডেটাক্লাসে দুটি নতুন ক্ষেত্র রয়েছে: বইটি যে ভাষায় লেখা হয়েছে এবং পৃষ্ঠার সংখ্যা। 'ভাষা' ক্ষেত্রের 'অজানা' এর একটি ডিফল্ট মান রয়েছে যা নির্দেশ করে যে ব্যবহারকারী যদি এই বিশদটি প্রদান না করে তবে এটি 'অজানা' তে ডিফল্ট হয়। 'পৃষ্ঠার সংখ্যা' ক্ষেত্রটি ঐচ্ছিক এবং খালি রাখা যেতে পারে (কোনও সেট নয়)।
থেকে pydantic আমদানি বেস মডেলক্লাস বই ( বেস মডেল ) :
শিরোনাম: str
লেখক: str
মুক্তির বছর: int
ভাষা: str = 'অজানা'
পৃষ্ঠা: int = কোনোটিই নয়
ইনপুট = {
'শিরোনাম' : 'কষ্ট' ,
'লেখক' : 'আদম' ,
'মুক্তির বছর' : 2023 ,
'ভাষা' : 'ইংরেজি' ,
'পৃষ্ঠা' : 2. 3. 4
}
বই = বই ( ** ইনপুট )
ছাপা ( 'বইয়ের বিবরণ:' , বই শিরোনাম , বই লেখক , বই মুক্তির বছর , বই ভাষা , বই পৃষ্ঠাগুলি )
আমরা কোডের এই লাইনগুলি অনুলিপি করতে পারি এবং ফলাফলগুলি পর্যবেক্ষণ করতে কম্পাইলারে পেস্ট করতে পারি:
থেকে pydantic আমদানি বেস মডেলক্লাস বই ( বেস মডেল ) :
শিরোনাম: str
লেখক: str
মুক্তির বছর: int
ইনপুট = {
'শিরোনাম' : 'কষ্ট' ,
'লেখক' : 'আদম' ,
'মুক্তির বছর' : 2023
}
# একটি বইয়ের উদাহরণ তৈরি করা
চেষ্টা করুন :
বই = বই ( ** ইনপুট )
ছাপা ( 'বইয়ের বিবরণ:' , বই শিরোনাম , বই লেখক , বই মুক্তির বছর )
ছাড়া ব্যতিক্রম হিসাবে এইটা:
ছাপা ( 'ত্রুটি:' , এইটা )
এই ঐচ্ছিক ক্ষেত্র এবং ডিফল্ট মানগুলি অন্তর্ভুক্ত করে, Pydantic নিশ্চিত করে যে ব্যবহারকারীরা নির্দিষ্ট বিশদ প্রদান না করলেও ডেটা ভাল-গঠিত এবং সামঞ্জস্যপূর্ণ থাকে।
পদ্ধতি 2: ছাত্র নিবন্ধন ফর্মের জন্য Pydantic এর ডেটাক্লাসের সাথে ডেটা পরিচালনা
কল্পনা করুন যে আমরা একটি স্কুল ইভেন্টের জন্য একটি নিবন্ধন ফর্ম তৈরি করছি। লোকেদের তাদের তথ্য লিখতে হবে এবং আমরা ভুল এড়াতে চাই। সেখানেই পাইডান্টিক ডেটাক্লাসগুলি সাহায্য করে। তারা নিশ্চিত করে যে ডেটা সঠিক এবং সহজেই এটি পরিচালনা করে।
পাইথন প্রজেক্টে প্রয়োজনীয় প্যাকেজ আনার পর, আমরা অংশগ্রহণকারীদের বিশদ বিবরণের জন্য 'স্টুডেন্ট' নামক একটি পাইডান্টিক ডেটাক্লাস তৈরি করে একটি পাইডান্টিক ডেটাক্লাস সংজ্ঞায়িত করি।
থেকে pydantic আমদানি বেস মডেল'ছাত্র' ক্লাস সেট আপ করতে ক্লাস ডেকোরেটর ব্যবহার করুন। এটি পাইডান্টিকের বেস মডেল থেকে উত্তরাধিকারসূত্রে প্রাপ্ত। ভিতরে, আমরা নাম, ইমেল, বিভাগ এবং ফোনের মতো গুণাবলীর নাম দিয়েছি, প্রতিটি তার ডেটা টাইপ সহ।
ক্লাস ছাত্র ( বেস মডেল ) :নাম: str
ইমেইল : str
বিভাগ: str
ফোন: str
এখন Pydantic ডেটাক্লাস ব্যবহার করে, ছাত্র ডেটা পরিচালনা করতে 'ছাত্র' ডেটাক্লাসের সাথে কাজ করুন:
তথ্য = {'নাম' : 'XYZ' ,
'ইমেইল' : 'xyz@student.com' ,
'বিভাগ' : 'এন্ড্রু' ,
'ফোন' : '0003-4567234'
}
এই অংশে, আমরা ভান করি যে কেউ সাইন আপ করে। যখন আমরা তাদের ডেটা ব্যবহার করে একটি 'ছাত্র' উদাহরণ তৈরি করি, তখন Pydantic এটি কাঠামোর সাথে খাপ খায় কিনা তা পরীক্ষা করে। যদি কোনও ত্রুটি থাকে, যেমন '@' ছাড়া একটি ইমেল বা একটি নন-স্ট্রিং বিভাগ, Pydantic থামে এবং সমস্যাটি ব্যাখ্যা করে।
ছাত্র = ছাত্র ( ** তথ্য )ছাপা ( 'ছাত্রের বিবরণ:' , ছাত্র )
Pydantic dataclasses ব্যবহার করে উন্নত ডেটা হ্যান্ডলিং আমাদেরকে একটি রেডি-টু-ব্যবহারের ডেটা দেয়। আমরা আরও ক্ষেত্র যোগ করতে পারি, ডিফল্ট সেট করতে পারি বা জটিল ডেটা সেটআপের সাথে কাজ করতে পারি। এই সব নিশ্চিত করে যে আমাদের ডেটা সংগঠিত থাকবে।
আউটপুটের কোড এবং স্নিপেট পর্যবেক্ষণের জন্য নিম্নলিখিতটিতে উল্লেখ করা হয়েছে:
থেকে pydantic আমদানি বেস মডেলক্লাস ছাত্র ( বেস মডেল ) :
নাম: str
ইমেইল : str
বিভাগ: str
ফোন: str
তথ্য = {
'নাম' : 'XYZ' ,
'ইমেইল' : 'xyz@student.com' ,
'বিভাগ' : 'এন্ড্রু' ,
'ফোন' : '0003-4567234'
}
ছাত্র = ছাত্র ( ** তথ্য )
ছাপা ( 'ছাত্রের বিবরণ:' , ছাত্র )
আউটপুট পর্যবেক্ষণ করার পরে, আমরা এই সহজ উদাহরণে পাইডান্টিক ডেটাক্লাসগুলি সহজে ডেটা পরিচালনা করে। তারা নিশ্চিত করে যে ইনপুট আমরা যা চাই তা মেলে। এর মানে কম ত্রুটি এবং খুশি ব্যবহারকারী।
উপসংহার
পাইড্যান্টিক ডেটাক্লাসগুলি আমরা কীভাবে ডেটা নিয়ে কাজ করি তা সংহত করে। তারা গ্যারান্টি দেয় যে তথ্য উভয়ই সঠিক এবং প্রয়োজনীয় কাঠামোর সাথে খাপ খায়। এটি কম ত্রুটি এবং আরও ত্রুটিহীন অ্যাপ্লিকেশনে অনুবাদ করে৷ Pydantic-এর সাথে, ডেভেলপাররা ডেটা সংক্রান্ত সমস্যা নিয়ে উদ্বেগ না করেই ভাল-কার্যকর অ্যাপ তৈরির জন্য তাদের প্রচেষ্টাকে উৎসর্গ করতে পারে। এটিকে শুধুমাত্র ডেটা পরিচালনার জন্য একটি ডেডিকেটেড টাস্ক ম্যানেজার হিসেবে ভাবুন, নিশ্চিত করুন যে সবকিছু শুরু থেকে শেষ পর্যন্ত মসৃণভাবে চলে।