ToolDeck

JSON থেকে YAML রূপান্তরকারী

JSON কে YAML ফরম্যাটে রূপান্তর করুন

একটি উদাহরণ চেষ্টা করুন

JSON ইনপুট

YAML আউটপুট

স্থানীয়ভাবে চলে · গোপন তথ্য পেস্ট করা নিরাপদ
YAML এখানে দেখাবে…

JSON থেকে YAML রূপান্তর কী?

JSON থেকে YAML রূপান্তর JavaScript Object Notation থেকে YAML Ain't Markup Language-এ ডেটা স্থানান্তর করে। উভয় ফরম্যাট একই ডেটা কাঠামো উপস্থাপন করে — অবজেক্ট, অ্যারে, স্ট্রিং, সংখ্যা, বুলিয়ান, null — তবে ভিন্ন সিনট্যাক্স ব্যবহার করে। JSON কার্লি ব্রেস, স্কোয়ার ব্র্যাকেট ও কমার উপর নির্ভর করে। YAML ইন্ডেন্টেশন ও লাইন বিরতি ব্যবহার করে, যা সাধারণ লেখার মতো সহজে পাঠযোগ্য আউটপুট তৈরি করে। XML-এর বিপরীতে, কোনো ফরম্যাটেরই স্কিমার প্রয়োজন নেই।

YAML মানব-বান্ধব ডেটা সিরিয়ালাইজেশন ফরম্যাট হিসেবে ডিজাইন করা হয়েছে। এটি Kubernetes ম্যানিফেস্ট, Docker Compose ফাইল, Ansible প্লেবুক, GitHub Actions ওয়ার্কফ্লো এবং অনেক CI/CD সিস্টেমের জন্য ডিফল্ট কনফিগারেশন ভাষা। যখন আপনার উৎস ডেটা JSON-এ থাকে এবং লক্ষ্য সিস্টেম YAML আশা করে, তখন আপনার এমন একটি কনভার্টার দরকার যা প্রতিটি মান, ধরন ও নেস্টিং স্তর নির্ভুলভাবে সংরক্ষণ করে।

অনলাইনে JSON থেকে YAML রূপান্তর তখন কার্যকর যখন আপনি API প্রতিক্রিয়া বা রপ্তানি করা ডেটা JSON-এ পান এবং সেটি YAML কনফিগ ফাইলে পেস্ট করতে হয়। রূপান্তরে সমস্ত মানক JSON ধরনের জন্য কোনো তথ্য হারায় না — স্ট্রিং, সংখ্যা, বুলিয়ান, null, অ্যারে ও অবজেক্ট সরাসরি তাদের YAML সমতুল্যে রূপান্তরিত হয়। কোলন বা বিশেষ অক্ষর ধারণকারী মানগুলি স্বয়ংক্রিয়ভাবে উদ্ধৃত হয় যাতে আউটপুট বৈধ YAML হয়।

কেন JSON থেকে YAML রূপান্তর করবেন?

YAML কনফিগ ফাইলের মানক, আর API সাধারণত JSON ফেরত দেয়। এদের মধ্যে রূপান্তর আপনাকে ডেটা হাতে পুনরায় লেখা ছাড়াই প্রতিটি কাজের জন্য সঠিক ফরম্যাট ব্যবহার করতে দেয়।

তাৎক্ষণিক রূপান্তর
JSON পেস্ট করুন এবং সঙ্গে সঙ্গে YAML আউটপুট পান। সার্ভার প্রক্রিয়াকরণের জন্য অপেক্ষা নেই, ফাইল আপলোড নেই, রেট লিমিট নেই।
🔒
গোপনীয়তা রক্ষায় প্রক্রিয়াকরণ
আপনার ডেটা কখনো ব্রাউজার ছেড়ে যায় না। রূপান্তরটি সম্পূর্ণরূপে আপনার ডিভাইসে JavaScript-এ চলে, তাই ক্রেডেনশিয়াল, টোকেন ও API কী গোপন থাকে।
🔀
যেকোনো JSON কাঠামো পরিচালনা করে
গভীরভাবে নেস্টেড অবজেক্ট, বড় অ্যারে, মিশ্র ধরন, Unicode স্ট্রিং ও বিশেষ অক্ষর সবই সঠিকভাবে রূপান্তরিত হয়। এই টুলটি সম্পূর্ণ ডেটা কাঠামো সংরক্ষণ করে।
📋
কোনো অ্যাকাউন্ট বা ইনস্টল প্রয়োজন নেই
পৃষ্ঠা খুলুন এবং রূপান্তর শুরু করুন। কোনো সাইন-আপ নেই, কোনো এক্সটেনশন নেই, কোনো CLI টুল ইনস্টল করতে হবে না। ব্রাউজার আছে এমন যেকোনো ডিভাইসে কাজ করে।

JSON থেকে YAML ব্যবহারের ক্ষেত্র

Kubernetes ও Docker Compose
API প্রতিক্রিয়া ও রপ্তানি করা কনফিগ প্রায়ই JSON হিসেবে আসে। Kubernetes ম্যানিফেস্ট, Helm চার্ট ও Docker Compose ফাইলে সরাসরি ব্যবহারের জন্য সেগুলি YAML-এ রূপান্তর করুন।
CI/CD পাইপলাইন কনফিগারেশন
GitHub Actions, GitLab CI, CircleCI ও Azure Pipelines সবই YAML ব্যবহার করে। প্রোগ্রামগতভাবে JSON থেকে পাইপলাইন কনফিগ তৈরি করার সময়, কমিট করার আগে আউটপুট রূপান্তর করুন।
Ansible প্লেবুক
Ansible প্লেবুক ও ইনভেন্টরি ফাইলের জন্য YAML প্রত্যাশা করে। ক্লাউড API থেকে JSON ইনভেন্টরি রপ্তানি Ansible-এর প্রয়োজনীয় YAML ফরম্যাটে রূপান্তর করুন।
API প্রতিক্রিয়া পরীক্ষা
REST API JSON ফেরত দেয়। নেস্টেড প্রতিক্রিয়া YAML-এ রূপান্তর করলে ডেটা স্তরবিন্যাস এক নজরে দৃশ্যমান হয়, যা ব্র্যাকেট-ভারী JSON-এর চেয়ে দ্রুত পড়া যায়।
কনফিগারেশন ফাইল স্থানান্তর
JSON-ভিত্তিক কনফিগ (যেমন tsconfig.json, package.json রপ্তানি) থেকে YAML-ভিত্তিক টুলে অ্যাপ্লিকেশন স্থানান্তর করার সময়, পুনরায় টাইপ না করে মানগুলি একসাথে রূপান্তর করুন।
শিক্ষা ও ডকুমেন্টেশন
শিক্ষার্থী ও প্রযুক্তি লেখকরা ফরম্যাটের মধ্যে ডেটা কাঠামো কীভাবে মেলে তা বুঝতে পাশাপাশি JSON/YAML ব্যবহার করেন। কনভার্টার তাৎক্ষণিক, নির্ভুল উদাহরণ প্রদান করে।

JSON বনাম YAML তুলনা

JSON ও YAML একই ডেটা উপস্থাপন করতে পারে, তবে তাদের সিনট্যাক্স ও সক্ষমতা নির্দিষ্ট ব্যবহারের ক্ষেত্রে গুরুত্বপূর্ণ উপায়ে ভিন্ন।

বৈশিষ্ট্যJSONYAML
SyntaxCurly braces, square brackets, colons, commasIndentation-based, colons, dashes
ReadabilityModerate — nested brackets become denseHigh — visual hierarchy from indentation
CommentsNot allowed (RFC 8259)Supported with #
Multi-line stringsEscape sequences only (\n)Block scalars with | or >
Data typesstring, number, boolean, null, object, arraySame plus date, timestamp, binary
File sizeSlightly larger (brackets + quotes)Slightly smaller (no brackets)
Trailing commasNot allowedNot applicable (no commas)
SpecRFC 8259 / ECMA-404YAML 1.2 (yaml.org)

রূপান্তরের পরে YAML-এর সাধারণ ফাঁদ

YAML-এ পার্সিং নিয়ম আছে যা JSON থেকে আসা ডেভেলপারদের অবাক করে। এই চারটি সমস্যা রূপান্তরিত আউটপুটে সবচেয়ে বেশি বাগ তৈরি করে।

উদ্ধৃতিহীন yes/no বুলিয়ান হয়ে যায়
YAML 1.1 পার্সার উদ্ধৃতিহীন yes, no, on, off, true ও false-কে বুলিয়ান হিসেবে গণ্য করে। আপনার JSON-এ স্ট্রিং মান "yes" বা "no" থাকলে, কিছু পুরনো টুল YAML আউটপুটে উদ্ধৃতি না দিলে সেটি বুলিয়ান হিসেবে পার্স হতে পারে। YAML 1.2 শুধুমাত্র true/false-এ সীমাবদ্ধ।
ইন্ডেন্টেশন ত্রুটি পার্সিং ভেঙে দেয়
YAML কাঠামো নির্ধারণে ইন্ডেন্টেশন ব্যবহার করে। একটি অতিরিক্ত বা অনুপস্থিত স্পেস অর্থ পরিবর্তন করতে বা পার্স ত্রুটি তৈরি করতে পারে। JSON-এর বিপরীতে, যেখানে ভুল স্থানে কমা স্পষ্ট ত্রুটি দেয়, YAML ইন্ডেন্টেশন ভুল অলক্ষিতে আপনার ডেটা স্তরবিন্যাস পরিবর্তন করতে পারে।
মানের মধ্যে কোলন থাকলে উদ্ধৃতি চিহ্ন প্রয়োজন
কোলনের পরে স্পেস (": ") হলো YAML-এর কী-ভ্যালু বিভাজক। আপনার JSON স্ট্রিংয়ে সেই ক্রম থাকলে (যেমন "http://example.com"), YAML আউটপুটে মানটি উদ্ধৃত করতে হবে। বেশিরভাগ কনভার্টার এটি স্বয়ংক্রিয়ভাবে পরিচালনা করে।
বহু-ডকুমেন্ট ফাইল
YAML --- দ্বারা পৃথক করা একটি ফাইলে একাধিক ডকুমেন্ট সমর্থন করে। JSON-এর কোনো সমতুল্য নেই। JSON কনফিগের অ্যারে রূপান্তর করার সময়, প্রতিটি উপাদান পৃথক YAML ডকুমেন্ট হতে পারে, বা অ্যারে আইটেম হিসেবে থাকতে পারে। আপনার লক্ষ্য টুল কোন ফরম্যাট প্রত্যাশা করে তা জানুন।

কোড উদাহরণ

প্রোগ্রামগতভাবে JSON থেকে YAML রূপান্তরের জন্য বেশিরভাগ ভাষায় YAML সিরিয়ালাইজেশন লাইব্রেরি প্রয়োজন। স্ট্যান্ডার্ড লাইব্রেরি JSON পার্সিং পরিচালনা করে; YAML আউটপুটের জন্য অতিরিক্ত প্যাকেজ প্রয়োজন।

JavaScript (Node.js)
import YAML from 'js-yaml'

const json = '{"host":"localhost","port":3000,"debug":true}'
const obj = JSON.parse(json)
const yamlStr = YAML.dump(obj, { indent: 2 })
console.log(yamlStr)
// → host: localhost
// → port: 3000
// → debug: true
Python
import json, yaml

json_str = '{"host": "localhost", "port": 3000, "debug": true}'
data = json.loads(json_str)
yaml_str = yaml.dump(data, default_flow_style=False, sort_keys=False)
print(yaml_str)
# → host: localhost
# → port: 3000
# → debug: true
Go
package main

import (
    "encoding/json"
    "fmt"
    "gopkg.in/yaml.v3"
)

func main() {
    jsonStr := `{"host":"localhost","port":3000,"debug":true}`
    var data map[string]interface{}
    json.Unmarshal([]byte(jsonStr), &data)

    yamlBytes, _ := yaml.Marshal(data)
    fmt.Println(string(yamlBytes))
    // → debug: true
    // → host: localhost
    // → port: 3000
}
CLI (yq / jq + Python)
# Using yq (https://github.com/mikefarah/yq)
echo '{"host":"localhost","port":3000}' | yq -P
# → host: localhost
# → port: 3000

# Using Python one-liner
echo '{"host":"localhost","port":3000}' | python3 -c "import sys,json,yaml; print(yaml.dump(json.load(sys.stdin), default_flow_style=False))"

প্রায়শই জিজ্ঞাসিত প্রশ্ন

JSON থেকে YAML রূপান্তরে কি কোনো তথ্য হারায়?
না, সমস্ত মানক JSON ধরনের জন্য রূপান্তরে কোনো তথ্য হারায় না। স্ট্রিং, সংখ্যা, বুলিয়ান, null, অ্যারে ও অবজেক্টের সরাসরি YAML সমতুল্য আছে। রূপান্তরিত YAML পার্স করে একই ডেটা পাওয়া যায়। একমাত্র সৌন্দর্যগত পার্থক্য হলো ফরম্যাটিং: YAML ব্রেসের পরিবর্তে ইন্ডেন্টেশন ব্যবহার করে।
YAML কি JSON-এর সবকিছু উপস্থাপন করতে পারে?
হ্যাঁ। YAML হলো JSON-এর সুপারসেট (YAML 1.2 অনুযায়ী)। প্রতিটি বৈধ JSON ডকুমেন্ট বৈধ YAML-ও। YAML JSON-এর অনুপস্থিত বৈশিষ্ট্য যোগ করে: মন্তব্য, অ্যাংকর/এলিয়াস, মাল্টি-লাইন স্ট্রিং ও তারিখের মতো অতিরিক্ত স্কেলার ধরন।
Kubernetes ও Docker কেন JSON-এর পরিবর্তে YAML ব্যবহার করে?
YAML মন্তব্য সমর্থন করে, যা ইনফ্রাস্ট্রাকচার কনফিগারেশন ডকুমেন্ট করার জন্য অপরিহার্য। এটি গভীরভাবে নেস্টেড কাঠামোর জন্যও বেশি পাঠযোগ্য কারণ ইন্ডেন্টেশন ব্র্যাকেটের জটিলতা প্রতিস্থাপন করে। Kubernetes আসলে JSON ও YAML উভয়ই গ্রহণ করে, তবে কমিউনিটি ও সমস্ত অফিসিয়াল ডকুমেন্টেশন YAML ব্যবহার করে।
বড় JSON ফাইল কীভাবে পরিচালনা করব?
এই কনভার্টার আপনার ব্রাউজারে চলে, তাই এটি কোনো সমস্যা ছাড়াই কয়েক মেগাবাইট পর্যন্ত ফাইল পরিচালনা করতে পারে। খুব বড় ফাইলের জন্য (৫০MB+), yq-এর মতো CLI টুল বা PyYAML লাইব্রেরি সহ Python স্ক্রিপ্ট ব্যবহার করুন। এগুলি ডেটা স্ট্রিম হিসেবে প্রক্রিয়া করে এবং কম মেমোরি ব্যবহার করে।
কনভার্টার কি কী ক্রম সংরক্ষণ করে?
হ্যাঁ। কনভার্টার JSON ইনপুটে যে ক্রমে কী দেখা যায় সে ক্রমেই YAML কী আউটপুট করে। JSON অবজেক্ট প্রযুক্তিগতভাবে স্পেক অনুযায়ী ক্রমহীন, তবে বাস্তবে পার্সার সন্নিবেশ ক্রম সংরক্ষণ করে এবং এই টুল YAML আউটপুটে সেই ক্রম বজায় রাখে।
আউটপুট কোন YAML সংস্করণ অনুসরণ করে?
আউটপুট YAML 1.2 নিয়ম অনুসরণ করে। এর মানে শুধুমাত্র true ও false বুলিয়ান লিটারেল হিসেবে গণ্য হয় (yes/no/on/off নয়)। ভুল ব্যাখ্যা হতে পারে এমন স্ট্রিং স্বয়ংক্রিয়ভাবে উদ্ধৃত হয় পার্সিং অস্পষ্টতা রোধ করতে।
এই টুলে API কী ও টোকেন পেস্ট করা কি নিরাপদ?
হ্যাঁ। রূপান্তরটি সম্পূর্ণরূপে আপনার ব্রাউজারে JavaScript ব্যবহার করে চলে। কোনো ডেটা কোনো সার্ভারে পাঠানো হয় না। আপনি এটি যাচাই করতে পারেন ব্রাউজারের নেটওয়ার্ক ইন্সপেক্টর খুলে এবং দেখতে পারেন যে রূপান্তরের সময় কোনো অনুরোধ করা হয় না।

সম্পর্কিত টুলস

JSON ফরম্যাটার ও বিউটিফায়ারসিনট্যাক্স হাইলাইটিং সহ JSON ফরম্যাট ও বিউটিফাই করুনJSON ভ্যালিডেটরJSON সিনট্যাক্স ও স্ট্রাকচার ভ্যালিডেট করুনJSON ডিফদুটি JSON অবজেক্ট তুলনা করুন ও পার্থক্য হাইলাইট করুনJSON প্রিটি প্রিন্টপাঠযোগ্যতার জন্য কাস্টমাইজযোগ্য ইন্ডেন্টেশন সহ JSON প্রিটি প্রিন্ট করুনJSON মিনিফায়ারহোয়াইটস্পেস সরিয়ে JSON মিনিফাই ও কম্প্যাক্ট করুনJSON থেকে CSVJSON অ্যারেকে CSV ফরম্যাটে রূপান্তর করুনJSON থেকে TypeScriptJSON থেকে TypeScript ইন্টারফেস তৈরি করুনJSON থেকে C# ক্লাসJSON থেকে C# ক্লাস তৈরি করুনJSON থেকে Go StructJSON থেকে Go struct তৈরি করুনJSON থেকে PythonJSON থেকে Python dataclass তৈরি করুনJSON থেকে JavaJSON থেকে Java POJO ক্লাস তৈরি করুনJSON থেকে DartfromJson ও toJson সহ JSON থেকে Dart ক্লাস তৈরি করুন