Je travaille maintenant sur l'extraction d'informations d'un fichier JSON en Ruby. Alors, comment puis-je extraire uniquement les nombres situés à côté du "score" de Word à partir du fichier texte suivant? Par exemple, je veux obtenir 0,6748984055823062, 0,6280145725181376, etc.
{
"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
},
Ce que j'ai essayé, c'est que je pouvais lire un fichier et définir le fichier texte sur une variable de hachage à l'aide de la méthode JSON.
require 'json'
json = JSON.parse(json_string)
Vous pouvez utiliser Array#map
pour collecter les avis.
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]
J'espère que cela t'aides!
En utilisant la classe JSON
:
Importer un fichier:
require "json"
file = File.open "/path/to/your/file.json"
data = JSON.load file
Facultativement, vous pouvez le fermer maintenant:
file.close
Le fichier ressemble à ceci:
{
"title": "Facebook",
"url": "https://www.facebook.com",
"posts": [
"lemon-car",
"dead-memes"
]
}
Le fichier peut maintenant être lu comme ceci:
data["title"]
=> "Facebook"
data.keys
=> ["title", "url", "posts"]
data['posts']
=> ["lemon-car", "dead-memes"]
data["url"]
=> "https://www.facebook.com"
J'espère que cela a aidé!
data_hash = JSON.parse(File.read('file-name-to-be-read.json'))
Il suffit ensuite de cartographier les données!
reviews = data_hash['sentiment_analysis'].first
reviews.map do |sentiment, reviews|
puts "#{sentiment} #{reviews.map { |review| review['score'] }}"
end
Je pense que c'est la réponse la plus simple.