আমি JSON.NET ব্যবহার করতে শুরু করেছি JSON ফর্ম্যাটে একটি স্ট্রিংকে অবজেক্ট বা বিপরীতে রূপান্তর করতে। আমি জসন.এনইটি ফ্রেমওয়ার্কে নিশ্চিত নই, জেএসওএন-এ কোনও স্ট্রিংকে এক্সএমএল ফর্ম্যাট এবং বিপরীতে রূপান্তর করা সম্ভব?
আমি JSON.NET ব্যবহার করতে শুরু করেছি JSON ফর্ম্যাটে একটি স্ট্রিংকে অবজেক্ট বা বিপরীতে রূপান্তর করতে। আমি জসন.এনইটি ফ্রেমওয়ার্কে নিশ্চিত নই, জেএসওএন-এ কোনও স্ট্রিংকে এক্সএমএল ফর্ম্যাট এবং বিপরীতে রূপান্তর করা সম্ভব?
উত্তর:
হ্যাঁ. এই সুনির্দিষ্ট উদ্দেশ্যে সহায়তার পদ্ধতি রয়েছে এমন জসনকনভার্ট ক্লাস ব্যবহার করা:
// To convert an XML node contained in string xml into a JSON string
XmlDocument doc = new XmlDocument();
doc.LoadXml(xml);
string jsonText = JsonConvert.SerializeXmlNode(doc);
// To convert JSON text contained in string json into an XML node
XmlDocument doc = JsonConvert.DeserializeXmlNode(json);
ডকুমেন্টেশন এখানে: JSON.NET এর সাথে JSON এবং XML এর মধ্যে রূপান্তর
হ্যাঁ, আপনি এটি করতে পারেন (আমি করি) তবে রূপান্তর করার সময় কিছু প্যারাডক্স সম্পর্কে সচেতন থাকুন এবং যথাযথভাবে পরিচালনা করুন। আপনি সমস্ত ইন্টারফেস সম্ভাবনার সাথে স্বয়ংক্রিয়ভাবে মেনে চলতে পারবেন না, এবং রূপান্তর নিয়ন্ত্রণে সীমিত অন্তর্নির্মিত সমর্থন রয়েছে- অনেক JSON কাঠামো এবং মানগুলি স্বয়ংক্রিয়ভাবে উভয় উপায়ে রূপান্তর করা যায় না। মনে রাখবেন আমি নিউটসনফট জেএসওএন লাইব্রেরি এবং এমএস এক্সএমএল লাইব্রেরির সাথে ডিফল্ট সেটিংস ব্যবহার করছি, তাই আপনার মাইলেজটি পৃথক হতে পারে:
{}
বা নেস্টেড-অ্যারেতে পরিণত হতে পারে [ {} {} ...]
। আপনি এই দুটি জাভাস্ক্রিপ্টে আলাদাভাবে গ্রাস করবেন ইত্যাদি। একই স্কিমার সাথে মেনে চলার এক্সএমএলের বিভিন্ন উদাহরণ আসলে এইভাবে বিভিন্ন জেএসএন কাঠামো তৈরি করতে পারে। আপনি কিছুটা (তবে অগত্যা সমস্ত নয়) ক্ষেত্রে এটিকে জড়িত করতে আপনার উপাদানটিতে json: অ্যারে = 'ট্রু' যুক্ত করতে পারেন।একটি নতুন আপডেট এটি পরিবর্তন করে (এটি নির্দেশ করার জন্য জোন স্টোরিকে ধন্যবাদ): https://www.newtonsoft.com/json/help/htML/T_Newtonsoft_Json_NullValueHandling.htm
আপনি খেয়াল করেছেন এমন যে কোনও সমস্যা উল্লেখ করার জন্য নির্দ্বিধায় দ্বিধা করুন, আমি পিছনে রূপান্তর করার সাথে সাথে স্ট্রিং প্রস্তুত ও পরিষ্কার করার জন্য আমার নিজস্ব কাস্টম রুটিনগুলি বিকাশ করেছি। আপনার পরিস্থিতি প্রিপ / ক্লিনআপের জন্য কল করতে পারে বা নাও পারে। স্ট্যাকসম্যান যেমন উল্লেখ করেছে, আপনার অবস্থার জন্য আসলে আপনার প্রয়োজন হতে পারে যে আপনি বস্তুর মধ্যে রূপান্তর করুন ... এটি উপরে উল্লিখিত ক্যাভেটগুলি পরিচালনা করতে উপযুক্ত ইন্টারফেস এবং একাধিক মামলার বিবৃতি / ইত্যাদি জড়িত থাকতে পারে।
। নেট ফ্রেমওয়ার্কের সাহায্যে আপনি এই রূপান্তরগুলি করতে পারেন:
জেএসএন টু এক্সএমএল: সিস্টেম.রুনটাইম.সরিয়ালাইজেশন.জসন ব্যবহার করে
var xml = XDocument.Load(JsonReaderWriterFactory.CreateJsonReader(
Encoding.ASCII.GetBytes(jsonString), new XmlDictionaryReaderQuotas()));
এক্সএমএল টু জেএসওএন: সিস্টেম.ওয়েব.স্ক্রিপ্ট.শিরাইজেশন ব্যবহার করে
var json = new JavaScriptSerializer().Serialize(GetXmlData(XElement.Parse(xmlString)));
private static Dictionary<string, object> GetXmlData(XElement xml)
{
var attr = xml.Attributes().ToDictionary(d => d.Name.LocalName, d => (object)d.Value);
if (xml.HasElements) attr.Add("_value", xml.Elements().Select(e => GetXmlData(e)));
else if (!xml.IsEmpty) attr.Add("_value", xml.Value);
return new Dictionary<string, object> { { xml.Name.LocalName, attr } };
}
আমি নিশ্চিত নই যে এই ধরণের রূপান্তরটির কোনও বিন্দু রয়েছে (হ্যাঁ, অনেকে এটি করেন তবে বেশিরভাগ ক্ষেত্রে বৃত্তাকার ছিদ্রটি বৃত্তাকার ছিদ্র দিয়ে জোর করে দেওয়া হয়) - কাঠামোগত প্রতিবন্ধকতা মিল নেই, এবং রূপান্তরটি ক্ষয়ক্ষতিযুক্ত। সুতরাং আমি এই ধরনের বিন্যাস থেকে বিন্যাস রূপান্তর বিরুদ্ধে সুপারিশ করব।
তবে আপনি যদি এটি করেন তবে প্রথমে জসন থেকে অবজেক্টে রূপান্তর করুন, তারপরে অবজেক্ট থেকে এক্সএমএল (এবং বিপরীত দিকের বিপরীতে)। সরাসরি রূপান্তর করা কুৎসিত আউটপুট, তথ্য হ্রাস, বা উভয়ই হতে পারে।
ডেভিড ব্রাউন এর উত্তরের জন্য ধন্যবাদ । আমার JSON.Net 3.5 এর ক্ষেত্রে, রূপান্তর পদ্ধতিগুলি জসনকনভার্ট স্থিত শ্রেণীর অধীনে রয়েছে:
XmlNode myXmlNode = JsonConvert.DeserializeXmlNode(myJsonString); // is node not note
// or .DeserilizeXmlNode(myJsonString, "root"); // if myJsonString does not have a root
string jsonString = JsonConvert.SerializeXmlNode(myXmlNode);
বহিরাগত সমাবেশ / প্রকল্পটি ব্যবহার না করার আশায় গ্রহণযোগ্য সমাধানের বিকল্প কোড খুঁজতে আমি দীর্ঘ সময় অনুসন্ধান করেছি। ডায়নামিকজেসন প্রকল্পের উত্স কোডটির জন্য আমি নিম্নলিখিত ধন্যবাদটি নিয়ে এসেছি :
public XmlDocument JsonToXML(string json)
{
XmlDocument doc = new XmlDocument();
using (var reader = JsonReaderWriterFactory.CreateJsonReader(Encoding.UTF8.GetBytes(json), XmlDictionaryReaderQuotas.Max))
{
XElement xml = XElement.Load(reader);
doc.LoadXml(xml.ToString());
}
return doc;
}
দ্রষ্টব্য: আমি এক্সপ্যাথ উদ্দেশ্যে XElement এর চেয়ে একটি এক্সএমএল ডকুমেন্ট চেয়েছিলাম। এছাড়াও, এই কোডটি স্পষ্টতই কেবল JSON থেকে XML এ যায়, বিপরীত করার বিভিন্ন উপায় রয়েছে।
এক্সএমএলকে জসনতে রূপান্তর করতে এখানে পুরো সি # কোড দেওয়া আছে
public static class JSon
{
public static string XmlToJSON(string xml)
{
XmlDocument doc = new XmlDocument();
doc.LoadXml(xml);
return XmlToJSON(doc);
}
public static string XmlToJSON(XmlDocument xmlDoc)
{
StringBuilder sbJSON = new StringBuilder();
sbJSON.Append("{ ");
XmlToJSONnode(sbJSON, xmlDoc.DocumentElement, true);
sbJSON.Append("}");
return sbJSON.ToString();
}
// XmlToJSONnode: Output an XmlElement, possibly as part of a higher array
private static void XmlToJSONnode(StringBuilder sbJSON, XmlElement node, bool showNodeName)
{
if (showNodeName)
sbJSON.Append("\"" + SafeJSON(node.Name) + "\": ");
sbJSON.Append("{");
// Build a sorted list of key-value pairs
// where key is case-sensitive nodeName
// value is an ArrayList of string or XmlElement
// so that we know whether the nodeName is an array or not.
SortedList<string, object> childNodeNames = new SortedList<string, object>();
// Add in all node attributes
if (node.Attributes != null)
foreach (XmlAttribute attr in node.Attributes)
StoreChildNode(childNodeNames, attr.Name, attr.InnerText);
// Add in all nodes
foreach (XmlNode cnode in node.ChildNodes)
{
if (cnode is XmlText)
StoreChildNode(childNodeNames, "value", cnode.InnerText);
else if (cnode is XmlElement)
StoreChildNode(childNodeNames, cnode.Name, cnode);
}
// Now output all stored info
foreach (string childname in childNodeNames.Keys)
{
List<object> alChild = (List<object>)childNodeNames[childname];
if (alChild.Count == 1)
OutputNode(childname, alChild[0], sbJSON, true);
else
{
sbJSON.Append(" \"" + SafeJSON(childname) + "\": [ ");
foreach (object Child in alChild)
OutputNode(childname, Child, sbJSON, false);
sbJSON.Remove(sbJSON.Length - 2, 2);
sbJSON.Append(" ], ");
}
}
sbJSON.Remove(sbJSON.Length - 2, 2);
sbJSON.Append(" }");
}
// StoreChildNode: Store data associated with each nodeName
// so that we know whether the nodeName is an array or not.
private static void StoreChildNode(SortedList<string, object> childNodeNames, string nodeName, object nodeValue)
{
// Pre-process contraction of XmlElement-s
if (nodeValue is XmlElement)
{
// Convert <aa></aa> into "aa":null
// <aa>xx</aa> into "aa":"xx"
XmlNode cnode = (XmlNode)nodeValue;
if (cnode.Attributes.Count == 0)
{
XmlNodeList children = cnode.ChildNodes;
if (children.Count == 0)
nodeValue = null;
else if (children.Count == 1 && (children[0] is XmlText))
nodeValue = ((XmlText)(children[0])).InnerText;
}
}
// Add nodeValue to ArrayList associated with each nodeName
// If nodeName doesn't exist then add it
List<object> ValuesAL;
if (childNodeNames.ContainsKey(nodeName))
{
ValuesAL = (List<object>)childNodeNames[nodeName];
}
else
{
ValuesAL = new List<object>();
childNodeNames[nodeName] = ValuesAL;
}
ValuesAL.Add(nodeValue);
}
private static void OutputNode(string childname, object alChild, StringBuilder sbJSON, bool showNodeName)
{
if (alChild == null)
{
if (showNodeName)
sbJSON.Append("\"" + SafeJSON(childname) + "\": ");
sbJSON.Append("null");
}
else if (alChild is string)
{
if (showNodeName)
sbJSON.Append("\"" + SafeJSON(childname) + "\": ");
string sChild = (string)alChild;
sChild = sChild.Trim();
sbJSON.Append("\"" + SafeJSON(sChild) + "\"");
}
else
XmlToJSONnode(sbJSON, (XmlElement)alChild, showNodeName);
sbJSON.Append(", ");
}
// Make a string safe for JSON
private static string SafeJSON(string sIn)
{
StringBuilder sbOut = new StringBuilder(sIn.Length);
foreach (char ch in sIn)
{
if (Char.IsControl(ch) || ch == '\'')
{
int ich = (int)ch;
sbOut.Append(@"\u" + ich.ToString("x4"));
continue;
}
else if (ch == '\"' || ch == '\\' || ch == '/')
{
sbOut.Append('\\');
}
sbOut.Append(ch);
}
return sbOut.ToString();
}
}
প্রদত্ত XML স্ট্রিংটিকে JSON এ রূপান্তর করতে, কেবল নীচের মত XMLToJSON () ফাংশনটি কল করুন।
string xml = "<menu id=\"file\" value=\"File\"> " +
"<popup>" +
"<menuitem value=\"New\" onclick=\"CreateNewDoc()\" />" +
"<menuitem value=\"Open\" onclick=\"OpenDoc()\" />" +
"<menuitem value=\"Close\" onclick=\"CloseDoc()\" />" +
"</popup>" +
"</menu>";
string json = JSON.XmlToJSON(xml);
// json = { "menu": {"id": "file", "popup": { "menuitem": [ {"onclick": "CreateNewDoc()", "value": "New" }, {"onclick": "OpenDoc()", "value": "Open" }, {"onclick": "CloseDoc()", "value": "Close" } ] }, "value": "File" }}
এই ফাংশন চেষ্টা করুন। আমি কেবল এটি লিখেছি এবং এটি পরীক্ষার খুব বেশি সুযোগ পাইনি, তবে আমার প্রাথমিক পরীক্ষাগুলি আশাব্যঞ্জক।
public static XmlDocument JsonToXml(string json)
{
XmlNode newNode = null;
XmlNode appendToNode = null;
XmlDocument returnXmlDoc = new XmlDocument();
returnXmlDoc.LoadXml("<Document />");
XmlNode rootNode = returnXmlDoc.SelectSingleNode("Document");
appendToNode = rootNode;
string[] arrElementData;
string[] arrElements = json.Split('\r');
foreach (string element in arrElements)
{
string processElement = element.Replace("\r", "").Replace("\n", "").Replace("\t", "").Trim();
if ((processElement.IndexOf("}") > -1 || processElement.IndexOf("]") > -1) && appendToNode != rootNode)
{
appendToNode = appendToNode.ParentNode;
}
else if (processElement.IndexOf("[") > -1)
{
processElement = processElement.Replace(":", "").Replace("[", "").Replace("\"", "").Trim();
newNode = returnXmlDoc.CreateElement(processElement);
appendToNode.AppendChild(newNode);
appendToNode = newNode;
}
else if (processElement.IndexOf("{") > -1 && processElement.IndexOf(":") > -1)
{
processElement = processElement.Replace(":", "").Replace("{", "").Replace("\"", "").Trim();
newNode = returnXmlDoc.CreateElement(processElement);
appendToNode.AppendChild(newNode);
appendToNode = newNode;
}
else
{
if (processElement.IndexOf(":") > -1)
{
arrElementData = processElement.Replace(": \"", ":").Replace("\",", "").Replace("\"", "").Split(':');
newNode = returnXmlDoc.CreateElement(arrElementData[0]);
for (int i = 1; i < arrElementData.Length; i++)
{
newNode.InnerText += arrElementData[i];
}
appendToNode.AppendChild(newNode);
}
}
}
return returnXmlDoc;
}
এখানে একটি সাধারণ স্নিপেট যা এক্সএমএমলনডকে (পুনরাবৃত্তভাবে) হ্যাশটেবলে রূপান্তর করে এবং একই সন্তানের একাধিক উদাহরণকে অ্যারে (অ্যারেলিস্ট হিসাবে) হিসাবে ভাগ করে দেয়। জ্যাশন লাইব্রেরির বেশিরভাগ দ্বারা হ্যাশটেবল সাধারণত জেএসএন রূপান্তর করতে গৃহীত হয়।
protected object convert(XmlNode root){
Hashtable obj = new Hashtable();
for(int i=0,n=root.ChildNodes.Count;i<n;i++){
object result = null;
XmlNode current = root.ChildNodes.Item(i);
if(current.NodeType != XmlNodeType.Text)
result = convert(current);
else{
int resultInt;
double resultFloat;
bool resultBoolean;
if(Int32.TryParse(current.Value, out resultInt)) return resultInt;
if(Double.TryParse(current.Value, out resultFloat)) return resultFloat;
if(Boolean.TryParse(current.Value, out resultBoolean)) return resultBoolean;
return current.Value;
}
if(obj[current.Name] == null)
obj[current.Name] = result;
else if(obj[current.Name].GetType().Equals(typeof(ArrayList)))
((ArrayList)obj[current.Name]).Add(result);
else{
ArrayList collision = new ArrayList();
collision.Add(obj[current.Name]);
collision.Add(result);
obj[current.Name] = collision;
}
}
return obj;
}
সিনচু ইটিএল - কয়েকটি লাইন কোডের সাহায্যে খুব সহজেই এক্সএমএলকে জেএসএনে রূপান্তর করতে উপলভুক্ত একটি ওপেন সোর্স লাইব্রেরি
এক্সএমএল -> জেএসএন:
using (var p = new ChoXmlReader("sample.xml"))
{
using (var w = new ChoJSONWriter("sample.json"))
{
w.Write(p);
}
}
জেএসন -> এক্সএমএল:
using (var p = new ChoJsonReader("sample.json"))
{
using (var w = new ChoXmlWriter("sample.xml"))
{
w.Write(p);
}
}
কিছু অতিরিক্ত সহায়তার জন্য কোডআউট কোড নিবন্ধ চেকআউট।
দাবি অস্বীকার: আমি এই গ্রন্থাগারের লেখক।
আমি ডেভিড ব্রাউন যেমন বলেছিলাম তেমনই করেছি তবে আমি নিম্নলিখিত ব্যতিক্রম পেয়েছি।
$exception {"There are multiple root elements. Line , position ."} System.Xml.XmlException
একটি সমাধানটি হ'ল এক্সএমএল ফাইলটিকে মূল উপাদান দিয়ে পরিবর্তন করতে হবে তবে এটি সর্বদা প্রয়োজন হয় না এবং এক্সএমএল স্ট্রিমের জন্য এটিও সম্ভব নাও হতে পারে। আমার সমাধান নীচে:
var path = Path.GetFullPath(Path.Combine(Environment.CurrentDirectory, @"..\..\App_Data"));
var directoryInfo = new DirectoryInfo(path);
var fileInfos = directoryInfo.GetFiles("*.xml");
foreach (var fileInfo in fileInfos)
{
XmlDocument doc = new XmlDocument();
XmlReaderSettings settings = new XmlReaderSettings();
settings.ConformanceLevel = ConformanceLevel.Fragment;
using (XmlReader reader = XmlReader.Create(fileInfo.FullName, settings))
{
while (reader.Read())
{
if (reader.NodeType == XmlNodeType.Element)
{
var node = doc.ReadNode(reader);
string json = JsonConvert.SerializeXmlNode(node);
}
}
}
}
এক্সএমএল উদাহরণ যা ত্রুটি উত্পন্ন করে:
<parent>
<child>
Text
</child>
</parent>
<parent>
<child>
<grandchild>
Text
</grandchild>
<grandchild>
Text
</grandchild>
</child>
<child>
Text
</child>
</parent>
আমি JSON কে XML এ রূপান্তর করতে নীচের পদ্ধতিগুলি ব্যবহার করেছি
List <Item> items;
public void LoadJsonAndReadToXML() {
using(StreamReader r = new StreamReader(@ "E:\Json\overiddenhotelranks.json")) {
string json = r.ReadToEnd();
items = JsonConvert.DeserializeObject <List<Item>> (json);
ReadToXML();
}
}
এবং
public void ReadToXML() {
try {
var xEle = new XElement("Items",
from item in items select new XElement("Item",
new XElement("mhid", item.mhid),
new XElement("hotelName", item.hotelName),
new XElement("destination", item.destination),
new XElement("destinationID", item.destinationID),
new XElement("rank", item.rank),
new XElement("toDisplayOnFod", item.toDisplayOnFod),
new XElement("comment", item.comment),
new XElement("Destinationcode", item.Destinationcode),
new XElement("LoadDate", item.LoadDate)
));
xEle.Save("E:\\employees.xml");
Console.WriteLine("Converted to XML");
} catch (Exception ex) {
Console.WriteLine(ex.Message);
}
Console.ReadLine();
}
আমি উপাদানগুলির প্রতিনিধিত্ব করতে আইটেম নামের ক্লাসটি ব্যবহার করেছি
public class Item {
public int mhid { get; set; }
public string hotelName { get; set; }
public string destination { get; set; }
public int destinationID { get; set; }
public int rank { get; set; }
public int toDisplayOnFod { get; set; }
public string comment { get; set; }
public string Destinationcode { get; set; }
public string LoadDate { get; set; }
}
এটি কাজ করে ....
JSON
স্ট্রিং রূপান্তর করার জন্য এটি XML
চেষ্টা করুন:
public string JsonToXML(string json)
{
XDocument xmlDoc = new XDocument(new XDeclaration("1.0", "utf-8", ""));
XElement root = new XElement("Root");
root.Name = "Result";
var dataTable = JsonConvert.DeserializeObject<DataTable>(json);
root.Add(
from row in dataTable.AsEnumerable()
select new XElement("Record",
from column in dataTable.Columns.Cast<DataColumn>()
select new XElement(column.ColumnName, row[column])
)
);
xmlDoc.Add(root);
return xmlDoc.ToString();
}
XML
এটি JSON
চেষ্টা করতে রূপান্তর করার জন্য :
public string XmlToJson(string xml)
{
XmlDocument doc = new XmlDocument();
doc.LoadXml(xml);
string jsonText = JsonConvert.SerializeXmlNode(doc);
return jsonText;
}
জেএসএন বা এক্সএমএল স্ট্রিংকে পার্স করার জন্য নিজের কোড লেখার পরিবর্তে তৃতীয় পক্ষের লাইব্রেরি ব্যবহার করুন। যদি এটি একবার ব্যবহার করে তবে এটি অনলাইনে রূপান্তর করার চেষ্টা করুন। জসন থেকে এক্সএমএল https://www.easycodeforall.com/Json2XML.jsp এক্সএমএল থেকে জসন https://www.easycodeforall.com/XML2Json.jsp