我有来自网络服务的数据:
[
{
"meter_id":"3",
"Values":[
{
"label":"SMAXSN",
"value":"E190912121751 01980"
},
{
"label":"MSG1",
"value":" PAS DE MESSAGE"
},
{
"label":"PCOUP",
"value":"03"
},
{
"label":"EASF10",
"value":"000000000"
},
{
"label":"STGE",
"value":"003A0001"
},
{
"label":"URMS1",
"value":"235"
},
{
"label":"EASF06",
"value":"000000000"
},
{
"label":"EAST",
"value":"004191456"
},
{
"label":"PREF",
"value":"03"
},
{
"label":"SMAXSN-1",
"value":"E190911223945 01940"
},
{
"label":"DATE",
"value":"E190912152027"
},
{
"label":"EASD02",
"value":"000610281"
},
{
"label":"PJOURF+1",
"value":"00008001 NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE"
},
{
"label":"NJOURF+1",
"value":"00"
},
{
"label":"ADSC",
"value":"021775806277"
},
{
"label":"EASD03",
"value":"000045963"
},
{
"label":"LTARF",
"value":" BASE"
},
{
"label":"CCASN-1",
"value":"E190912143000 00144"
},
{
"label":"EASF01",
"value":"004191456"
},
{
"label":"EASD04",
"value":"000134889"
},
{
"label":"EASD01",
"value":"003400323"
},
{
"label":"SINSTS",
"value":"00326"
},
{
"label":"CCASN",
"value":"E190912150000 00156"
},
{
"label":"VTIC",
"value":"02"
},
{
"label":"IRMS1",
"value":"001"
},
{
"label":"EASF03",
"value":"000000000"
},
{
"label":"EASF04",
"value":"000000000"
},
{
"label":"EASF08",
"value":"000000000"
},
{
"label":"RELAIS",
"value":"000"
},
{
"label":"EASF02",
"value":"000000000"
},
{
"label":"NJOURF",
"value":"00"
},
{
"label":"NTARF",
"value":"01"
},
{
"label":"UMOY1",
"value":"E190912152000 236"
},
{
"label":"EASF05",
"value":"000000000"
},
{
"label":"PRM",
"value":"23545007228637"
},
{
"label":"timestamp",
"value":"2019-09-12T15:20:02+02:00"
},
{
"label":"EASF09",
"value":"000000000"
},
{
"label":"EASF07",
"value":"000000000"
},
{
"label":"NGTF",
"value":" BASE"
}
]
},
{
"meter_id":"5",
"Values":[
{
"label":"VTIC",
"value":"02"
},
{
"label":"EASD04",
"value":"000000000"
},
{
"label":"EAST",
"value":"003048661"
},
{
"label":"NTARF",
"value":"01"
},
{
"label":"CCASN-1",
"value":"E190912143000 00060"
},
{
"label":"EASF05",
"value":"000000000"
},
{
"label":"EASF10",
"value":"000000000"
},
{
"label":"IRMS1",
"value":"000"
},
{
"label":"EASD03",
"value":"000000000"
},
{
"label":"ADSC",
"value":"021775056027"
},
{
"label":"CCASN",
"value":"E190912150000 00058"
},
{
"label":"URMS1",
"value":"241"
},
{
"label":"EASF07",
"value":"000000000"
},
{
"label":"DATE",
"value":"E190912152021"
},
{
"label":"MSG1",
"value":" PAS DE MESSAGE"
},
{
"label":"PJOURF+1",
"value":"00008001 NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE"
},
{
"label":"PRM",
"value":"23544717793089"
},
{
"label":"LTARF",
"value":" BASE"
},
{
"label":"EASF06",
"value":"000000000"
},
{
"label":"NJOURF",
"value":"00"
},
{
"label":"EASF04",
"value":"000000000"
},
{
"label":"EASD02",
"value":"000329795"
},
{
"label":"timestamp",
"value":"2019-09-12T15:20:09+02:00"
},
{
"label":"EASF08",
"value":"000000000"
},
{
"label":"EASF09",
"value":"000000000"
},
{
"label":"SMAXSN-1",
"value":"E190911071004 01100"
},
{
"label":"NGTF",
"value":" BASE"
},
{
"label":"SMAXSN",
"value":"E190912071628 01110"
},
{
"label":"PREF",
"value":"06"
},
{
"label":"NJOURF+1",
"value":"00"
},
{
"label":"EASD01",
"value":"002718866"
},
{
"label":"EASF03",
"value":"000000000"
},
{
"label":"STGE",
"value":"003A4001"
},
{
"label":"RELAIS",
"value":"000"
},
{
"label":"EASF02",
"value":"000000000"
},
{
"label":"SINSTS",
"value":"00076"
},
{
"label":"UMOY1",
"value":"E190912152000 240"
},
{
"label":"PCOUP",
"value":"06"
},
{
"label":"EASF01",
"value":"003048661"
}
]
}
]
解析后,我应该得到一个包含 2 个项目的 meters 数组。
这是我的结构:
type Meter struct {
MeterID string `json:"meter_id"`
Values []Line `json:"Values"`
}
type Line struct {
Label string `json:"label"`
Value string `json:"value"`
}
当我显示原始 JSON 时:
var data []map[string]interface{}
body, err := ioutil.ReadAll(res.Body)
err = json.Unmarshal(body, &data)
logger.SLog.Debug(data)
我可以看到我看到了几个 meter 项目
但是当我尝试用以下方法解析它时:
var meters []Meter
err = json.NewDecoder(res.Body).Decode(&meters)
我还尝试用以下方法解析数据:
body, err := ioutil.ReadAll(res.Body)
err = json.Unmarshal(body, &meters)
if err != nil {
logger.SLog.Debug(err)
}
logger.SLog.Debug(meters)
但同样的结果,我在米中只得到 1 项。
为什么?
最佳答案
有点奇怪。我在 Go Playground 上试过这段代码,没问题,返回 2 个项目,看:
package main
import (
"encoding/json"
"strings"
"fmt"
)
type Meter struct {
MeterID string `json:"meter_id"`
Values []Line `json:"Values"`
}
type Line struct {
Label string `json:"label"`
Value string `json:"value"`
}
func main() {
jsonData := `[{"meter_id":"3","Values":[{"label":"SMAXSN","value":"E190912121751 01980"},{"label":"MSG1","value":" PAS DE MESSAGE"},{"label":"PCOUP","value":"03"},{"label":"EASF10","value":"000000000"},{"label":"STGE","value":"003A0001"},{"label":"URMS1","value":"235"},{"label":"EASF06","value":"000000000"},{"label":"EAST","value":"004191456"},{"label":"PREF","value":"03"},{"label":"SMAXSN-1","value":"E190911223945 01940"},{"label":"DATE","value":"E190912152027"},{"label":"EASD02","value":"000610281"},{"label":"PJOURF+1","value":"00008001 NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE"},{"label":"NJOURF+1","value":"00"},{"label":"ADSC","value":"021775806277"},{"label":"EASD03","value":"000045963"},{"label":"LTARF","value":" BASE"},{"label":"CCASN-1","value":"E190912143000 00144"},{"label":"EASF01","value":"004191456"},{"label":"EASD04","value":"000134889"},{"label":"EASD01","value":"003400323"},{"label":"SINSTS","value":"00326"},{"label":"CCASN","value":"E190912150000 00156"},{"label":"VTIC","value":"02"},{"label":"IRMS1","value":"001"},{"label":"EASF03","value":"000000000"},{"label":"EASF04","value":"000000000"},{"label":"EASF08","value":"000000000"},{"label":"RELAIS","value":"000"},{"label":"EASF02","value":"000000000"},{"label":"NJOURF","value":"00"},{"label":"NTARF","value":"01"},{"label":"UMOY1","value":"E190912152000 236"},{"label":"EASF05","value":"000000000"},{"label":"PRM","value":"23545007228637"},{"label":"timestamp","value":"2019-09-12T15:20:02+02:00"},{"label":"EASF09","value":"000000000"},{"label":"EASF07","value":"000000000"},{"label":"NGTF","value":" BASE"}]},{"meter_id":"5","Values":[{"label":"VTIC","value":"02"},{"label":"EASD04","value":"000000000"},{"label":"EAST","value":"003048661"},{"label":"NTARF","value":"01"},{"label":"CCASN-1","value":"E190912143000 00060"},{"label":"EASF05","value":"000000000"},{"label":"EASF10","value":"000000000"},{"label":"IRMS1","value":"000"},{"label":"EASD03","value":"000000000"},{"label":"ADSC","value":"021775056027"},{"label":"CCASN","value":"E190912150000 00058"},{"label":"URMS1","value":"241"},{"label":"EASF07","value":"000000000"},{"label":"DATE","value":"E190912152021"},{"label":"MSG1","value":" PAS DE MESSAGE"},{"label":"PJOURF+1","value":"00008001 NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE"},{"label":"PRM","value":"23544717793089"},{"label":"LTARF","value":" BASE"},{"label":"EASF06","value":"000000000"},{"label":"NJOURF","value":"00"},{"label":"EASF04","value":"000000000"},{"label":"EASD02","value":"000329795"},{"label":"timestamp","value":"2019-09-12T15:20:09+02:00"},{"label":"EASF08","value":"000000000"},{"label":"EASF09","value":"000000000"},{"label":"SMAXSN-1","value":"E190911071004 01100"},{"label":"NGTF","value":" BASE"},{"label":"SMAXSN","value":"E190912071628 01110"},{"label":"PREF","value":"06"},{"label":"NJOURF+1","value":"00"},{"label":"EASD01","value":"002718866"},{"label":"EASF03","value":"000000000"},{"label":"STGE","value":"003A4001"},{"label":"RELAIS","value":"000"},{"label":"EASF02","value":"000000000"},{"label":"SINSTS","value":"00076"},{"label":"UMOY1","value":"E190912152000 240"},{"label":"PCOUP","value":"06"},{"label":"EASF01","value":"003048661"}]}]`
//fmt.Printf("json: %s", jsonData)
var meters []Meter
err := json.NewDecoder(strings.NewReader(jsonData)).Decode(&meters)
if err != nil {
fmt.Printf("error: %v", err)
return
}
jsonOut, err := json.Marshal(meters)
if err != nil {
fmt.Println(err)
return
}
fmt.Printf("obj len: %d\n", len(meters))
fmt.Printf("jsonOut: %s\n", jsonOut)
}
输出:
obj len: 2
jsonOut: [{"meter_id":"3","Values":[{"label":"SMAXSN","value":"E190912121751 01980"},{"label":"MSG1","value":" PAS DE MESSAGE"},{"label":"PCOUP","value":"03"},{"label":"EASF10","value":"000000000"},{"label":"STGE","value":"003A0001"},{"label":"URMS1","value":"235"},{"label":"EASF06","value":"000000000"},{"label":"EAST","value":"004191456"},{"label":"PREF","value":"03"},{"label":"SMAXSN-1","value":"E190911223945 01940"},{"label":"DATE","value":"E190912152027"},{"label":"EASD02","value":"000610281"},{"label":"PJOURF+1","value":"00008001 NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE"},{"label":"NJOURF+1","value":"00"},{"label":"ADSC","value":"021775806277"},{"label":"EASD03","value":"000045963"},{"label":"LTARF","value":" BASE"},{"label":"CCASN-1","value":"E190912143000 00144"},{"label":"EASF01","value":"004191456"},{"label":"EASD04","value":"000134889"},{"label":"EASD01","value":"003400323"},{"label":"SINSTS","value":"00326"},{"label":"CCASN","value":"E190912150000 00156"},{"label":"VTIC","value":"02"},{"label":"IRMS1","value":"001"},{"label":"EASF03","value":"000000000"},{"label":"EASF04","value":"000000000"},{"label":"EASF08","value":"000000000"},{"label":"RELAIS","value":"000"},{"label":"EASF02","value":"000000000"},{"label":"NJOURF","value":"00"},{"label":"NTARF","value":"01"},{"label":"UMOY1","value":"E190912152000 236"},{"label":"EASF05","value":"000000000"},{"label":"PRM","value":"23545007228637"},{"label":"timestamp","value":"2019-09-12T15:20:02+02:00"},{"label":"EASF09","value":"000000000"},{"label":"EASF07","value":"000000000"},{"label":"NGTF","value":" BASE"}]},{"meter_id":"5","Values":[{"label":"VTIC","value":"02"},{"label":"EASD04","value":"000000000"},{"label":"EAST","value":"003048661"},{"label":"NTARF","value":"01"},{"label":"CCASN-1","value":"E190912143000 00060"},{"label":"EASF05","value":"000000000"},{"label":"EASF10","value":"000000000"},{"label":"IRMS1","value":"000"},{"label":"EASD03","value":"000000000"},{"label":"ADSC","value":"021775056027"},{"label":"CCASN","value":"E190912150000 00058"},{"label":"URMS1","value":"241"},{"label":"EASF07","value":"000000000"},{"label":"DATE","value":"E190912152021"},{"label":"MSG1","value":" PAS DE MESSAGE"},{"label":"PJOURF+1","value":"00008001 NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE NONUTILE"},{"label":"PRM","value":"23544717793089"},{"label":"LTARF","value":" BASE"},{"label":"EASF06","value":"000000000"},{"label":"NJOURF","value":"00"},{"label":"EASF04","value":"000000000"},{"label":"EASD02","value":"000329795"},{"label":"timestamp","value":"2019-09-12T15:20:09+02:00"},{"label":"EASF08","value":"000000000"},{"label":"EASF09","value":"000000000"},{"label":"SMAXSN-1","value":"E190911071004 01100"},{"label":"NGTF","value":" BASE"},{"label":"SMAXSN","value":"E190912071628 01110"},{"label":"PREF","value":"06"},{"label":"NJOURF+1","value":"00"},{"label":"EASD01","value":"002718866"},{"label":"EASF03","value":"000000000"},{"label":"STGE","value":"003A4001"},{"label":"RELAIS","value":"000"},{"label":"EASF02","value":"000000000"},{"label":"SINSTS","value":"00076"},{"label":"UMOY1","value":"E190912152000 240"},{"label":"PCOUP","value":"06"},{"label":"EASF01","value":"003048661"}]}]
关于json - 从 GET 发出解析 Json 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57907867/
我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我正在使用ruby1.9解析以下带有MacRoman字符的csv文件#encoding:ISO-8859-1#csv_parse.csvName,main-dialogue"Marceu","Giveittohimóhe,hiswife."我做了以下解析。require'csv'input_string=File.read("../csv_parse.rb").force_encoding("ISO-8859-1").encode("UTF-8")#=>"Name,main-dialogue\r\n\"Marceu\",\"Giveittohim\x97he,hiswife.\"\
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳
简而言之错误:NOTE:Gem::SourceIndex#add_specisdeprecated,useSpecification.add_spec.Itwillberemovedonorafter2011-11-01.Gem::SourceIndex#add_speccalledfrom/opt/local/lib/ruby/site_ruby/1.8/rubygems/source_index.rb:91./opt/local/lib/ruby/gems/1.8/gems/rails-2.3.8/lib/rails/gem_dependency.rb:275:in`==':und
我有一个非常简单的RubyRack服务器,例如:app=Proc.newdo|env|req=Rack::Request.new(env).paramspreq.inspect[200,{'Content-Type'=>'text/plain'},['Somebody']]endRack::Handler::Thin.run(app,:Port=>4001,:threaded=>true)每当我使用JSON对象向服务器发送POSTHTTP请求时:{"session":{"accountId":String,"callId":String,"from":Object,"headers":
我正在尝试使用Curbgem执行以下POST以解析云curl-XPOST\-H"X-Parse-Application-Id:PARSE_APP_ID"\-H"X-Parse-REST-API-Key:PARSE_API_KEY"\-H"Content-Type:image/jpeg"\--data-binary'@myPicture.jpg'\https://api.parse.com/1/files/pic.jpg用这个:curl=Curl::Easy.new("https://api.parse.com/1/files/lion.jpg")curl.multipart_form_
无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD