Получить номер из API и поместить его в переменную

Я хочу получить значение цены usd в этом API и поместить его в переменную: https://api.coingecko.com/api/v3/simple/price?ids=veco&vs_currencies=usd

Я уже пробовал этот код, но получаю ошибку:

public static void StartGet()
    {
        HttpWebRequest WebReq = (HttpWebRequest)WebRequest.Create(string.Format(VECO.VecoPriceURL));

        WebReq.Method = "GET";

        HttpWebResponse WebResp = (HttpWebResponse)WebReq.GetResponse();

        string jsonString;
        using (Stream stream = WebResp.GetResponseStream())
        {
            StreamReader reader = new StreamReader(stream, System.Text.Encoding.UTF8);
            jsonString = reader.ReadToEnd();
        }

        List<VECO.Coin> items = JsonConvert.DeserializeObject<List<VECO.Coin>>(jsonString);

        foreach (var item in items)
        {
            Console.WriteLine(item.usd);
        }
    }

public class VECO
{
    public static string VecoPriceURL = "https://api.coingecko.com/api/v3/simple/price?ids=veco&vs_currencies=usd";

    public class Coin
    {
        public string usd { get; set; }
    }
}

ОШИБКА:

Newtonsoft.Json.JsonSerializationException: 'Cannot deserialize the current 
JSON object (e.g. {"name":"value"}) into type 
'System.Collections.Generic.List`1[ConsoleProgram.VECO+Coin]' because the 
type requires a JSON array (e.g. [1,2,3]) to deserialize correctly.
To fix this error either change the JSON to a JSON array (e.g. [1,2,3]) or 
change the deserialized type so that it is a normal .NET type (e.g. not a 
primitive type like integer, not a collection type like an array or List<T>) 
that can be deserialized from a JSON object. JsonObjectAttribute can also be 
added to the type to force it to deserialize from a JSON object.
Path 'veco', line 1, position 8.'
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
3
0
216
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Ваши структуры данных должны немного отличаться.

public class Veco
{
    public decimal usd { get; set; }
}

public class RootObject
{
    public Veco veco { get; set; }
}

Обратите внимание, что Json не является массивом или списком, поэтому вам также необходимо использовать List<> в методе JsonConvert.DeserializeObject. Вместо этого вам нужно следующее.

var result = JsonConvert.DeserializeObject<RootObject>(jsonString);

Пример,

var jsonString = @"{'veco':{'usd':0.01558532}}";
var result = JsonConvert.DeserializeObject<RootObject>(jsonString);
Console.WriteLine($"USD Rate : {result.veco.usd}");

Вывод

USD Rate 0.01558532

Переписывая свой метод,

 public static void StartGet()
 {
        HttpWebRequest WebReq = (HttpWebRequest)WebRequest.Create(string.Format(VECO.VecoPriceURL));

        WebReq.Method = "GET";

        HttpWebResponse WebResp = (HttpWebResponse)WebReq.GetResponse();

        string jsonString;
        using (Stream stream = WebResp.GetResponseStream())
        {
            StreamReader reader = new StreamReader(stream, System.Text.Encoding.UTF8);
            jsonString = reader.ReadToEnd();
        }

        var item = JsonConvert.DeserializeObject<RootObject>(jsonString);
        Console.WriteLine(item.veco.usd);
 }

Обновлять

Основываясь на вашем комментарии, я бы переписал ваш метод следующим образом. Вам больше не нужна структура данных.

public static void StartGet(string id)
{
        var url = $"https://api.coingecko.com/api/v3/simple/price?ids = {id}&vs_currencies=usd";
        HttpWebRequest WebReq = (HttpWebRequest)WebRequest.Create(url);
        WebReq.Method = "GET";
        HttpWebResponse WebResp = (HttpWebResponse)WebReq.GetResponse();
        string jsonString;
        using (Stream stream = WebResp.GetResponseStream())
        {
            StreamReader reader = new StreamReader(stream, System.Text.Encoding.UTF8);
            jsonString = reader.ReadToEnd();
        }

       var result = JsonConvert.DeserializeObject<JToken>(jsonString);
       Console.WriteLine($"For {id},USD Rate : {result[id].Value<string>("usd")}");
}

Теперь вы можете использовать метод следующим образом

StartGet("veco");
StartGet("eos");
StartGet("uraniumx");

Вывод

For veco,USD Rate : 0.01581513
For eos,USD Rate : 2.42
For uraniumx,USD Rate : 0.890397

@ariadarkkkis Рад помочь вам. Пожалуйста, отметьте его как ответ, если он помог вам решить проблему.

Anu Viswan 27.01.2019 03:25

И как я могу использовать эту строку var result = JsonConvert.DeserializeObject<RootObject>(jsonString);, если я хочу использовать StartGet() как метод. Как StartGet(string url,...)

aria darkkkis 27.01.2019 03:31

Для получения и печати результата вы можете выполнить var items = JsonConvert.DeserializeObject<RootObject>(jsonString); Console.WriteLine(item.veco.usd)

Anu Viswan 27.01.2019 03:33

Если вы все еще этого не понимаете, я могу обновить свой ответ с помощью вашего модифицированного метода StartGet. Дай мне знать

Anu Viswan 27.01.2019 03:35

Я знаю. Но я хочу добавить в это приложение больше монет, таких как Биткойн и некоторые другие монеты. У каждого из них, как вы сказали, есть public class COIN_NAME и public class RootObject. Мне нужен этот метод StartGet(), чтобы получить стоимость каждой монеты в долларах США, которую я хочу. Например, я даю URL-адрес биткойна и получаю значение в долларах США из json и многих других монет. С приведенным выше кодом я должен использовать этот StartGet() для каждой монеты, которую я хочу получить в долларах США.

aria darkkkis 27.01.2019 03:38

У меня есть другой класс, такой же, как класс VECO, но называемый биткойн, и я хочу, чтобы StartGet() возвращал usd для многих из этих классов. VECO, Bitcoin и т. д. Отредактированный вами метод StartGet() возвращает только значение usd класса VECO.

aria darkkkis 27.01.2019 03:51

хм... не могли бы вы поделиться другим примером идентификатора, как у veco?

Anu Viswan 27.01.2019 03:57

@ariadarkkkis, пожалуйста, проверьте ответ сейчас. я обновил его.

Anu Viswan 27.01.2019 04:19

Другие вопросы по теме

Похожие вопросы

Образец приложения с информацией о пакете приложения UWP — где отображается удостоверение пакета
Привязка динамического списка к столбцу ComboBox в DataGrid работает только до фактического отображения списка
Проблема с прямым сообщением бота на весь мой сервер
Как я могу медленно остановить скорость ходьбы персонажа до 0, прежде чем коснуться двери?
Как использовать абстрактные классы в С#
ASP.NET MVC Возвращает последнюю запись в таблице для вошедшего в систему пользователя
Получить значение params Expression<Func<T, object>>[] exps как условие where, а также получить имя свойств и присвоенные им значения
Я не вижу добавленных значений для переменных в столбцах в Visual Studio, но вижу их на сервере SQL. Почему?
Как заархивировать/объединить по ключу множество источников, используя реактивный .net?
Вставить, если не существует в БД, ничего не делать, если существует в БД, и удалить, если не существует в списке