{"id":3754,"date":"2012-09-13T08:58:34","date_gmt":"2012-09-12T23:58:34","guid":{"rendered":"http:\/\/www.moonmile.net\/blog\/archives\/3754"},"modified":"2013-10-03T11:40:39","modified_gmt":"2013-10-03T02:40:39","slug":"cexcel-vba-%e3%81%a7-jquery-%e3%81%ae%e3%82%88%e3%81%86%e3%81%ab%e3%82%a2%e3%82%af%e3%82%bb%e3%82%b9%e3%81%a7%e3%81%8d%e3%82%8bc%e3%83%a9%e3%82%a4%e3%83%96%e3%83%a9%e3%83%aa%e3%82%92%e4%bd%9c","status":"publish","type":"post","link":"http:\/\/www.moonmile.net\/blog\/archives\/3754","title":{"rendered":"[C#]Excel VBA \u3067 jQuery \u306e\u3088\u3046\u306b\u30a2\u30af\u30bb\u30b9\u3067\u304d\u308bC#\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u4f5c\u308b"},"content":{"rendered":"<p>Excel VBA \u3067 jQuery \u306e\u3088\u3046\u306b\u30a2\u30af\u30bb\u30b9\u3067\u304d\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u4f5c\u308c\u308b\u304b\uff1f | Moonmile Solutions Blog<br \/>\n<a href=\"http:\/\/www.moonmile.net\/blog\/archives\/3217\">http:\/\/www.moonmile.net\/blog\/archives\/3217<\/a><\/p>\n<p>\u306a\u3068\u3053\u308d\u306e\u7d9a\u304d\u3002\u3068\u8a00\u3046\u304b\u3001\u3042\u306e\u3068\u304d\u306f Excel VBA \u5185\u306b\u9589\u3058\u3066\u306a\u3044\u3068\u4f7f\u3044\u3065\u3089\u3044\u306e\u3067\u306f\uff1f\u3068\u601d\u3063\u3066\u3044\u305f\u306e\u3067\u3059\u304c\u3001Excel VBA \u304b\u3089 COM \u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u547c\u3073\u51fa\u3059\u3001\u3068\u3044\u3046\u65b9\u6cd5\u3067\u3082\u3044\u3044\u3053\u3068\u306b\u6c17\u3065\u304d\u307e\u3057\u305f\u3002\u305d\u3053\u3067\u3001C# \u306e\u76f8\u4e92\u904b\u7528\uff08COM\u30a2\u30af\u30bb\u30b9\uff09\u3092\u5229\u7528\u3057\u3066\u3001Excel \u3092 jQuery \u98a8\u306b\u4f7f\u3046\u30e9\u30a4\u30d6\u30e9\u30ea\u4f5c\u6210\u306e\u7d9a\u304d\u304a\u3070\u3002<\/p>\n<p>\u25a0\u7528\u6cd5<\/p>\n<p>\u3053\u3093\u306a\u30b3\u30fc\u30c9\u3092\u66f8\u3044\u3066\u5b9f\u884c\u3092\u3059\u308b\u3068\u3001<\/p>\n<pre class=\"brush: vb; title: ; notranslate\" title=\"\">\r\nSub test()\r\n    ' \u521d\u671f\u5316\r\n    Dim obj As New ExQuery.Query\r\n    obj.SetApplication Excel.Application\r\n\r\n    obj.Cell(&quot;A1&quot;).Text = &quot;\u6700\u521d&quot;\r\n    obj.Cell(&quot;A2:B10&quot;).Text = &quot;\u57cb\u3081\u308b&quot;\r\n    ' \u80cc\u666f\u8272\u3092\u8d64\u306b\u8a2d\u5b9a\r\n    obj.Cell(&quot;A2&quot;).CSS(&quot;background-color&quot;) = RGB(255, 0, 0)\r\n\r\n    ' \u6587\u5b57\u8272\u3068\u80cc\u666f\u8272\u3092\u5909\u3048\u308b\r\n    Dim v As Long\r\n    v = RGB(0, 0, 255)\r\n    With obj.Cell(&quot;A3&quot;)\r\n        '.CSS(&quot;color&quot;) = RGB(255, 255, 255)\r\n        .CSS(&quot;color&quot;) = &quot;#FF00000&quot;\r\n        .CSS(&quot;background-color&quot;) = RGB(0, 0, 255)\r\n    End With\r\nEnd Sub\r\n<\/pre>\n<p>\u4ee5\u4e0b\u306e\u3088\u3046\u306b Excel \u306e\u30b7\u30fc\u30c8\u3092\u64cd\u4f5c\u3067\u304d\u307e\u3059\u3002<\/p>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2012\/09\/wpid-dworkblogimage20120913_01org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2012\/09\/wpid-dworkblogimage20120913_01thum.jpg\" border=\"0\" \/><\/a><\/p>\n<p>\u5148\u884c\u304d\u306f\u8868\u3092\u7c21\u5358\u306b\u4f5c\u308b\u3068\u304b\u3001\u691c\u7d22\u3092\u697d\u306b\u3059\u308b\u3068\u304b\u3092\u5b9f\u88c5\u3057\u305f\u3044\u3067\u3059\u306d\u3002<\/p>\n<p>\u25a0C#\u306e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9<\/p>\n<p>\u9762\u5012\u306a\u306e\u3067\u5168\u6587\u3092\u6652\u3057\u3066\u304a\u304d\u307e\u3059\u3002\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3092\u4f5c\u308b\u6642\u306b\u3001<\/p>\n<ul>\n<li>Visual Studio 2010 \u306f\u7ba1\u7406\u8005\u30e2\u30fc\u30c9\u3067\u8d77\u52d5\u3059\u308b<\/li>\n<li>Microsoft Excel \u3092\u53c2\u7167\u8a2d\u5b9a\u3059\u308b\u3002<\/li>\n<li>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u30d7\u30ed\u30d1\u30c6\u30a3\u3067\u300cCOM \u76f8\u4e92\u904b\u7528\u6a5f\u80fd\u306e\u767b\u9332\u300d\u3092\u30c1\u30a7\u30c3\u30af\u3059\u308b<\/li>\n<\/ul>\n<p>\u3092\u5fd8\u308c\u305a\u306b\u3002\u7ba1\u7406\u8005\u30e2\u30fc\u30c9\u306e\u307b\u3046\u306f\u3001COM \u3092\u30ec\u30b8\u30b9\u30c8\u30ea\u306b\u767b\u9332\u3059\u308b\u306e\u5fc5\u8981\u3067\u3059\u3002<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\nusing System;\r\nusing System.Collections.Generic;\r\nusing System.Linq;\r\nusing System.Text;\r\nusing Excel = Microsoft.Office.Interop.Excel;\r\nusing System.Runtime.InteropServices;\r\n\r\nnamespace Moonmile.ExQuery\r\n{\r\n\t&#x5B;ClassInterfaceAttribute(ClassInterfaceType.AutoDual)]\r\n\t&#x5B;ComVisible(true)]\r\n\tpublic class Query\r\n\t{\r\n\t\tprivate Excel.Application _app;\r\n\t\tprivate Excel.Workbook _book;\r\n\t\tprivate Excel.Worksheet _sheet;\r\n\t\tprivate Excel.Range _sel;\r\n\r\n\t\t\/\/\/\r\n\t\t\/\/\/ Initalize Excel.Application object\r\n\t\t\/\/\/\r\n\t\tpublic Excel.Application Application\r\n\t\t{\r\n\t\t\tget { return _app; }\r\n\t\t\tset\r\n\t\t\t{\r\n\t\t\t\t_app = value;\r\n\t\t\t\t_book = _app.ActiveWorkbook;\r\n\t\t\t\t_sheet = _app.ActiveSheet;\r\n\t\t\t\t_sel = _app.Selection;\r\n\t\t\t}\r\n\t\t}\r\n\t\tpublic void SetApplication(Excel.Application app)\r\n\t\t{\r\n\t\t\tthis.Application = app;\r\n\t\t}\r\n\r\n\t\tpublic Excel.Workbook Book\r\n\t\t{\r\n\t\t\tget { return _book; }\r\n\t\t\tset\r\n\t\t\t{\r\n\t\t\t\t_book = value;\r\n\t\t\t\t_sheet = _app.ActiveSheet;\r\n\t\t\t\t_sel = _app.Selection;\r\n\t\t\t}\r\n\t\t}\r\n\t\tpublic Excel.Worksheet Sheet\r\n\t\t{\r\n\t\t\tget { return _sheet; }\r\n\t\t\tset {\r\n\t\t\t\t_sheet = value;\r\n\t\t\t\t_sel = _app.Selection;\r\n\t\t\t}\r\n\t\t}\r\n\t\tpublic Excel.Range Selection\r\n\t\t{\r\n\t\t\tget { return _sel; }\r\n\t\t\tset { _sel = value; }\r\n\t\t}\r\n\r\n\t\t\/\/\/\r\n\t\t\/\/\/ default constructor\r\n\t\t\/\/\/\r\n\t\tpublic Query() { }\r\n\r\n\t\tpublic ExRange Cell( object row1, object col1 = null, object row2 = null, object col2 = null )\r\n\t\t{\r\n\t\t\tif (row1 == null)\r\n\t\t\t\treturn new ExRange();\r\n\r\n\t\t\tvar s = row1 as string;\r\n\t\t\tif (s != null)\r\n\t\t\t\treturn Cell(row1.ToString());\r\n\t\t\tif (row2 == null)\r\n\t\t\t\treturn Cell(int.Parse(row1.ToString()), int.Parse(col1.ToString()));\r\n\r\n\t\t\treturn Cell(\r\n\t\t\t\tint.Parse(row1.ToString()), int.Parse(col1.ToString()),\r\n\t\t\t\tint.Parse(row2.ToString()), int.Parse(col2.ToString()));\r\n\t\t}\r\n\r\n\t\t\/\/\/\r\n\t\t\/\/\/ pattern:\r\n\t\t\/\/\/ Cell(&quot;A1&quot;)\r\n\t\t\/\/\/ Cell(&quot;A1:B10&quot;)\r\n\t\t\/\/\/ Cell(&quot;#id&quot;)\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\tprotected ExRange Cell(string s)\r\n\t\t{\r\n\t\t\tExcel.Range rg;\r\n\t\t\tif (s.StartsWith(&quot;#&quot;))\r\n\t\t\t\trg = _sheet.get_Range(s.Substring(1));\r\n\t\t\telse if (s.StartsWith(&quot;.&quot;))\r\n\t\t\t\trg = _sheet.get_Range(s.Substring(1));\r\n\t\t\telse\r\n\t\t\t\trg = _sheet.get_Range(s);\r\n\t\t\treturn new ExRange(rg);\r\n\t\t}\r\n\r\n\t\t\/\/\/\r\n\t\t\/\/\/ pattern:\r\n\t\t\/\/\/ Cell(1,2)\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\tprotected ExRange Cell(int row, int col)\r\n\t\t{\r\n\t\t\tif (_sheet == null)\r\n\t\t\t\treturn new ExRange();\r\n\t\t\tvar rg = _sheet.Cells&#x5B;row, col];\r\n\t\t\treturn new ExRange(rg);\r\n\t\t}\r\n\r\n\t\t\/\/\/\r\n\t\t\/\/\/ pattern:\r\n\t\t\/\/\/ Cell(1,2,3,4)\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\t\/\/\/\r\n\t\tprotected ExRange Cell(int row1, int col1, int row2, int col2)\r\n\t\t{\r\n\t\t\tif (_sheet == null)\r\n\t\t\t\treturn new ExRange();\r\n\t\t\tvar rg = _sheet.Range&#x5B;\r\n\t\t\t\t_sheet.Cells&#x5B;row1, col1], _sheet.Cells&#x5B;row2, col2]];\r\n\t\t\treturn new ExRange(rg);\r\n\t\t}\r\n\t}\r\n\r\n\t&#x5B;ClassInterfaceAttribute(ClassInterfaceType.AutoDual)]\r\n\t&#x5B;ComVisible(true)]\r\n\tpublic class ExRange\r\n\t{\r\n\t\tprivate Excel.Range _range ;\r\n\t\tprivate CSS _css;\r\n\t\tprotected internal ExRange() { }\r\n\r\n\t\tpublic ExRange(Excel.Range rg)\r\n\t\t{\r\n\t\t\t_range = rg;\r\n\t\t\t_css = new CSS(_range);\r\n\t\t}\r\n\r\n\t\tpublic string Text\r\n\t\t{\r\n\t\t\tget { return _range.Value; }\r\n\t\t\tset { _range.Value = value; }\r\n\t\t}\r\n\r\n\t\tpublic CSS css\r\n\t\t{\r\n\t\t\tget { return _css; }\r\n\t\t}\r\n\r\n\t}\r\n\r\n\t&#x5B;ClassInterfaceAttribute(ClassInterfaceType.AutoDual)]\r\n\t&#x5B;ComVisible(true)]\r\n\tpublic class CSS\r\n\t{\r\n\t\tprivate Excel.Range _range;\r\n\r\n\t\tprotected internal CSS() { }\r\n\t\tprotected internal CSS(Excel.Range rg)\r\n\t\t{\r\n\t\t\t_range = rg;\r\n\t\t}\r\n\r\n\t\tpublic string this&#x5B;string key]\r\n\t\t{\r\n\t\t\tget\r\n\t\t\t{\r\n\t\t\t\tswitch (key.ToLower())\r\n\t\t\t\t{\r\n\t\t\t\t\tcase &quot;color&quot;:\r\n\t\t\t\t\t\treturn _range.Font.Color;\r\n\t\t\t\t\tcase &quot;background-color&quot;:\r\n\t\t\t\t\t\treturn _range.Interior.Color;\r\n\t\t\t\t}\r\n\t\t\t\treturn &quot;0&quot;;\r\n\t\t\t}\r\n\t\t\tset\r\n\t\t\t{\r\n\t\t\t\tif (value.StartsWith(&quot;#&quot;))\r\n\t\t\t\t{\r\n\t\t\t\t\tint r = Convert.ToInt32(value.Substring(1, 2), 16);\r\n\t\t\t\t\tint g = Convert.ToInt32(value.Substring(1, 4), 16);\r\n\t\t\t\t\tint b = Convert.ToInt32(value.Substring(1, 6), 16);\r\n\t\t\t\t\tvalue = (r + g * 0x100 + b * 0x10000).ToString();\r\n\t\t\t\t}\r\n\t\t\t\tswitch (key.ToLower())\r\n\t\t\t\t{\r\n\t\t\t\t\tcase &quot;color&quot;:\r\n\t\t\t\t\t\t_range.Font.Color = value;\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase &quot;background-color&quot;:\r\n\t\t\t\t\t\t_range.Interior.Color = value;\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n<\/pre>\n<p>\u25a0Excel VBA \u304b\u3089\u4f7f\u3046 COM \u4f5c\u6210\u306e\u30b3\u30c4<\/p>\n<p>\u3044\u304f\u3064\u304b\u5f15\u3063\u639b\u304b\u308b\u3068\u3053\u308d\u3092\u66f8\u304d\u4e0b\u3057\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n<p>Excel VBA \u306e\u300cinteger\u300d\u306f\u3001C# \u306e <del>Int64\/short<\/del>\u00a0 Int16\/short \u306b\u3042\u305f\u308a\u307e\u3059\u300216\u30d3\u30c3\u30c8\u306e\u6570\u5024\u306a\u3093\u3067\u3059\u306d\u3002\u306a\u306e\u3067\u3001COM \u306e\u30e1\u30bd\u30c3\u30c9\u306e\u5f15\u6570\u306f\u3001short \u306b\u3057\u3066\u304a\u304f\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u305d\u3046\u3057\u306a\u3044\u3068\u3001Excel VBA \u304b\u3089 COM \u306b\u5024\u3092\u5f15\u304d\u6e21\u3059\u3068\u304d\u306b\u30a8\u30e9\u30fc\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p>Cell \u30e1\u30bd\u30c3\u30c9\u306e\u5f15\u6570\u3067 object \u3092\u4f7f\u3063\u3066\u3044\u307e\u3059\u304c\u3001VBA \u306e Variant \u306f\u3001object \u3067\u3057\u304b\u53d6\u308c\u306a\u3044\u3088\u3046\u3067\u3059\u3002<br \/>\n\u6700\u521d\u306f\u3001Cell \u30e1\u30bd\u30c3\u30c9\u3092\u591a\u91cd\u5b9a\u7fa9\u3057\u3066\u516c\u958b\u3057\u3066\u3044\u305f\u306e\u3067\u3059\u304c\u3001VBA \u5074\u3067\u3001Cell\/Cell_2\/Cell_3 \u3068\u540d\u524d\u3092\u5909\u3048\u3089\u308c\u3066\u3057\u307e\u3046\u306e\u3067\u3001\u30c7\u30d5\u30a9\u30eb\u30c8\u5024\u3092\u4ed8\u3051\u3066\u540c\u3058\u540d\u524d\u3067\u5b9f\u884c\u3067\u304d\u308b\u3088\u3046\u306b\u5909\u3048\u307e\u3057\u305f\u3002<\/p>\n<p>Excel VBA \u306e\u30a4\u30f3\u30c6\u30ea\u30bb\u30f3\u30b9\u3092\u5229\u7528\u3059\u308b\u305f\u3081\u306b [ClassInterfaceAttribute(ClassInterfaceType.AutoDual)] \u3068\u3044\u3046\u5c5e\u6027\u3092\u3064\u3051\u307e\u3059\u3002\u5b9f\u306f AutoDual \u3092\u4f7f\u3046\u3068\u3001COM \u5074\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u304c\u5909\u308f\u308b\uff08\u30e1\u30bd\u30c3\u30c9\u306e\u9806\u756a\u304c\u5909\u308f\u308b\u306a\u3069\uff09\u305f\u3073\u306b\u3001VB \u5074\u306e\u30d3\u30eb\u30c9\u304c\u5fc5\u8981\u306b\u306a\u308b\u306e\u3067\u3059\u304c\u3001\u4eca\u56de\u306f Excel VBA \u3092\u5bfe\u8c61\u306b\u3059\u308b\u306e\u3067\u3053\u306e\u307e\u307e\u4f7f\u3063\u3066\u3044\u307e\u3059\u3002Excel VBA \u306e\u5834\u5408\u306f\u30a4\u30f3\u30bf\u30fc\u30d7\u30ea\u30bf\u7684\u306b COM \u3092\u8aad\u307f\u8fbc\u3080\u306e\u3067\u3001\u30bf\u30a4\u30d7\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u8d77\u52d5\u6642\u306b\u8aad\u307f\u8fbc\u3093\u3067\u304f\u308c\u308b\u305f\u3081\u3067\u3059\u3002\u3053\u306e\u3042\u305f\u308a\u306f\u3001\u4ee5\u4e0b\u306e\u30b5\u30a4\u30c8\u3092\u53c2\u8003\u306b\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<p>.NET\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092VB6\u304b\u3089\u4f7f\u7528\u3059\u308b\u305f\u3081\u306e\u65b9\u6cd5<br \/>\n<a href=\"http:\/\/www.sev.or.jp\/ijupiter\/world\/dc_interrop\/dotnet_com_interrop.html\">http:\/\/www.sev.or.jp\/ijupiter\/world\/dc_interrop\/dotnet_com_interrop.html<\/a><br \/>\nVisual Basic 6.0 \u304b\u3089 Visual Basic .NET \u307e\u305f\u306f Visual Basic 2005 \u30a2\u30bb\u30f3\u30d6\u30ea\u3092\u547c\u3073\u51fa\u3059\u65b9\u6cd5<br \/>\n<a href=\"http:\/\/support.microsoft.com\/default.aspx?scid=kb;ja;817248\">http:\/\/support.microsoft.com\/default.aspx?scid=kb;ja;817248<\/a><br \/>\nClassInterfaceType \u5217\u6319\u4f53 (System.Runtime.InteropServices)<br \/>\n<a href=\"http:\/\/msdn.microsoft.com\/ja-jp\/library\/system.runtime.interopservices.classinterfacetype(v=vs.110).aspx\">http:\/\/msdn.microsoft.com\/ja-jp\/library\/system.runtime.interopservices.classinterfacetype(v=vs.110).aspx<\/a><\/p>\n<p>\u25a0\u4eca\u5f8c\u306e\u4e88\u5b9a\uff1f<\/p>\n<p>css \u30e1\u30bd\u30c3\u30c9\u3092\u3061\u307e\u3061\u307e\u3068\u5b9f\u88c5\u3057\u3066\u3001Excel VBA \u306e\u8907\u96d1\u306a UI \u3092\u697d\u306b\u30a2\u30af\u30bb\u30b9\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b\u3068\u826f\u3044\u304b\u3082\u3002<br \/>\n\u3042\u3068\u3001C# \u3067\u66f8\u3044\u305f\u306e\u3067\u5185\u90e8\u7684\u306b LINQ \u304c\u4f7f\u3048\u307e\u3059\u3088\u306d\u3002Where\/Select \u30e1\u30bd\u30c3\u30c9\u7b49\u3092\u9069\u5f53\u306b\u516c\u958b\u3057\u3066\u3084\u308c\u3070\u3001Excel VBA \u3067 LINQ \u3092\u4f7f\u3063\u3066\u3044\u308b\u611f\u3058\u306b\u3001\u306a\u308b\u304b\u3082\u3057\u308c\u306a\u3044\u3002\u3068\u304b\u3068\u304b\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Excel VBA \u3067 jQuery \u306e\u3088\u3046\u306b\u30a2\u30af\u30bb\u30b9\u3067\u304d\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u4f5c\u308c\u308b\u304b\uff1f | Moonmile Solutions Blog http:\/\/www.moonmile.net\/blog\/archives\/3217 &hellip; <a href=\"http:\/\/www.moonmile.net\/blog\/archives\/3754\">\u7d9a\u304d\u3092\u8aad\u3080 <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[23,42],"tags":[],"class_list":["post-3754","post","type-post","status-publish","format-standard","hentry","category-csharp","category-excel-vba"],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/3754","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/comments?post=3754"}],"version-history":[{"count":5,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/3754\/revisions"}],"predecessor-version":[{"id":3758,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/3754\/revisions\/3758"}],"wp:attachment":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/media?parent=3754"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/categories?post=3754"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/tags?post=3754"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}