web-dev-qa-db-ja.com

RubyでJSONファイルから解析し、ネストされたハッシュから数値を抽出する

現在、RubyでJSONファイルから情報を抽出しています。次に、次のテキストファイルからWordの「スコア」の横にある数字だけを抽出するにはどうすればよいですか?たとえば、0.6748984055823062、0.6280145725181376を繰り返し取得したいです。

{
  "sentiment_analysis": [
    {
      "positive": [
        {
          "sentiment": "Popular",
          "topic": "games",
          "score": 0.6748984055823062,
          "original_text": "Popular games",
          "original_length": 13,
          "normalized_text": "Popular games",
          "normalized_length": 13,
          "offset": 0
        },
        {
          "sentiment": "engaging",
          "topic": "pop culture-inspired games",
          "score": 0.6280145725181376,
          "original_text": "engaging pop culture-inspired games",
          "original_length": 35,
          "normalized_text": "engaging pop culture-inspired games",
          "normalized_length": 35,
          "offset": 370
        },
     "negative": [
    {
      "sentiment": "get sucked into",
      "topic": "the idea of planning",
      "score": -0.7923352042939829,
      "original_text": "Students get sucked into the idea of planning",
      "original_length": 45,
      "normalized_text": "Students get sucked into the idea of planning",
      "normalized_length": 45,
      "offset": 342
    },
    {
      "sentiment": "be daunted",
      "topic": null,
      "score": -0.5734506634410159,
      "original_text": "initially be daunted",
      "original_length": 20,
      "normalized_text": "initially be daunted",
      "normalized_length": 20,
      "offset": 2104
    },

私が試したことは、JSONメソッドを使用してファイルを読み取り、テキストファイルをハッシュ変数に設定できることです。

require 'json'
json = JSON.parse(json_string)
19
Sookie J

Array#mapを使用してレビューを収集できます。

reviews = json['sentiment_analysis'][0]
positive_reviews = reviews['positive']
negative_reviews = reviews['negative']

positive_reviews.map { |review| review['score'] }
=> [0.6748984055823062, 0.6280145725181376]

negative_reviews.map { |review| review['score'] }
=> [-0.7923352042939829, -0.5734506634410159]

お役に立てれば!

6

JSONクラスを使用する:

ファイルのインポート:

require "json"
file = File.open "/path/to/your/file.json"
data = JSON.load file

オプションで、今すぐ閉じることができます:

file.close

ファイルは次のようになります。

{
  "title": "Facebook",
  "url": "https://www.facebook.com",
  "posts": [
    "lemon-car",
    "dead-memes"
  ]
}

これで、ファイルは次のように読み取ることができます。

data["title"]
=> "Facebook"
data.keys
=> ["title", "url", "posts"]
data['posts']
=> ["lemon-car", "dead-memes"]
data["url"]
=> "https://www.facebook.com"

これが役に立てば幸いです!

30
Michal Štein

ファイルからデータを解析する

data_hash = JSON.parse(File.read('file-name-to-be-read.json'))

次に、データをマッピングするだけです!

reviews = data_hash['sentiment_analysis'].first
reviews.map do |sentiment, reviews|
  puts "#{sentiment} #{reviews.map { |review| review['score'] }}"
end

これが最も簡単な答えだと思います。

9
Blair Anderson