首页 > 解决方案 > 如何解析以字符 'u' 为前缀的 JSON 字符串

问题描述

我有一个我试图解析的 JSON 字符串:

[{u'OrderItem': {u'OrderItemId': u'123456789', u'Title': u'Product Title', u'QuantityShipped': u'0', u'IsTransparency': u'false', u'QuantityOrdered': u'1', u'ItemTax': {u'CurrencyCode': u'USD', u'Amount': u'0.00'}, u'ASIN': u'123456789', u'SellerSKU': u'BBB-123456789', u'ConditionSubtypeId': u'New', u'ConditionId': u'New', u'PromotionDiscountTax': {u'CurrencyCode': u'USD', u'Amount': u'0.00'}, u'TaxCollection': {u'Model': u'MarketplaceFacilitator', u'ResponsibleParty': u'Random Services, Inc.'}, u'PromotionDiscount': {u'CurrencyCode': u'USD', u'Amount': u'0.00'}, u'ItemPrice': {u'CurrencyCode': u'USD', u'Amount': u'100.35'}, u'ProductInfo': {u'NumberOfItems': u'1'}, u'IsGift': u'false'}}]

我不确定为什么,但 JSON 的每个部分都以字母“u”为前缀,我不确定我能做些什么来解析它。

我在网上读到,在 python 中这是正常的,但在 rails 中我只是得到一个错误,有没有办法将它解析成 JSON?

标签: ruby-on-railsjsonruby

解决方案


如果可能的话,我会检查 webhook 提供的数据是否可以配置为正确的 JSON。如果不是,我会让 Python 将字符串转换为 JSON,因为你说这是可读的。

我没有使用 Python 的经验,所以可能有更好的方法来做到这一点,但这样的事情可以解决问题:

# to_json.py
import sys
import ast
import json

input  = sys.stdin.read().strip()
output = ''

if input:
    object = ast.literal_eval(input)
    output = json.dumps(object)

print(output)

现在在 Ruby 中,您可以执行以下操作:

require 'json' # not needed in Rails

string = "[{u'OrderItem': {u'OrderItemId': u'123456789', u'Title': u'Product Title', u'QuantityShipped': u'0', u'IsTransparency': u'false', u'QuantityOrdered': u'1', u'ItemTax': {u'CurrencyCode': u'USD', u'Amount': u'0.00'}, u'ASIN': u'123456789', u'SellerSKU': u'BBB-123456789', u'ConditionSubtypeId': u'New', u'ConditionId': u'New', u'PromotionDiscountTax': {u'CurrencyCode': u'USD', u'Amount': u'0.00'}, u'TaxCollection': {u'Model': u'MarketplaceFacilitator', u'ResponsibleParty': u'Random Services, Inc.'}, u'PromotionDiscount': {u'CurrencyCode': u'USD', u'Amount': u'0.00'}, u'ItemPrice': {u'CurrencyCode': u'USD', u'Amount': u'100.35'}, u'ProductInfo': {u'NumberOfItems': u'1'}, u'IsGift': u'false'}}]"

json = IO.popen('python to_json.py', 'r+') do |io|
  io.puts(string)
  io.close_write # closing write sends EOF, signalling the end of input
  io.read
end

JSON.parse(json)
#=> [{"OrderItem"=>{"ASIN"=>"123456789", "ConditionId"=>"New", "OrderItemId"=>"123456789", "Title"=>"Product Title", "IsGift"=>"false", "ConditionSubtypeId"=>"New", "SellerSKU"=>"BBB-123456789", "PromotionDiscountTax"=>{"CurrencyCode"=>"USD", "Amount"=>"0.00"}, "TaxCollection"=>{"Model"=>"MarketplaceFacilitator", "ResponsibleParty"=>"Random Services, Inc."}, "PromotionDiscount"=>{"CurrencyCode"=>"USD", "Amount"=>"0.00"}, "ItemPrice"=>{"CurrencyCode"=>"USD", "Amount"=>"100.35"}, "ProductInfo"=>{"NumberOfItems"=>"1"}, "QuantityShipped"=>"0", "IsTransparency"=>"false", "QuantityOrdered"=>"1", "ItemTax"=>{"CurrencyCode"=>"USD", "Amount"=>"0.00"}}}]

注意:这假设您的机器上安装了 Python,并且您已将 Python 脚本与 Ruby 脚本放在同一工作目录中。

Python 参考资料:

红宝石参考:


推荐阅读