Я извлекаю код json из API < /p>
Нет проблем с этим < /p>
Выход JSON - эта строка < /p>
\"[\\r\\n {\\r\\n \\\"PtsID\\\": 14061\\r\\n }\\r\\n]\"
< /code>
Но когда я пытаюсь преобразовать это в DataTable < /p>
Использование этой строки кода < /p>
Вот мой код < /p>
DataTable dt1 = (DataTable)JsonConvert.DeserializeObject(json, (typeof(DataTable)));
< /code>
Я получаю эту ошибку < /p>
newtonsoft.json.jsonserializationexception: 'неожиданный токен JSON
при чтении DataTable. Ожидается, что startarray, получил строку. PATH '', Line
1, позиция 46. HttpClient client = new HttpClient();
client.DefaultRequestHeaders.Accept.Add(
new MediaTypeWithQualityHeaderValue("application/json"));
string json = client.GetStringAsync(url).Result;
DataTable dt1 = (DataTable)JsonConvert.DeserializeObject(json, (typeof(DataTable)));
edit
Я посмотрел этот ответ здесь
Deserialize вложенный набор данных из json string с json.net
и изменил мой код на этот
class MyTableUtilClass
{
public string PtsID { get; set; }
public DataTable Table { get; set; }
}
HttpClient client = new HttpClient();
client.DefaultRequestHeaders.Accept.Add(
new MediaTypeWithQualityHeaderValue("application/json"));
string json = client.GetStringAsync(url).Result;
var myUtil = JsonConvert.DeserializeObject(json);
DataTable myTable = myUtil.Table;
< /code>
Но при достижении этой строки < /p>
var myUtil = JsonConvert.DeserializeObject(json);
< /code>
Я получаю эту ошибку < /p>
newtonsoft.json.jsonserializationexception: 'Ошибка преобразования значения »[
{
" ptsid ": 14061}]" type' encoder.frmcoder+mytabletlclaslclaslclaslclasclc. Path '', Line 1, положение 46. '< /p>
< /blockquote>
, которая является той же ошибкой, которую я получил до .. < /p>
Любое решение? В приложении < /p>
Вот код из API < /p>
[Route("api/SearchSelect")]
public string Get(string P1 = null, string P2 = null, string P3 = null, string P4 = null)
{
SqlConnection conn = new SqlConnection(gDBConn);
SqlCommand cmd = new SqlCommand("SearchSelect", conn);
cmd.CommandTimeout = 0;
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("@PtsName", P1));
cmd.Parameters.Add(new SqlParameter("@PtsNo", P2));
cmd.Parameters.Add(new SqlParameter("@RepCode", P3));
cmd.Parameters.Add(new SqlParameter("@RepText", P4));
try
{
conn.Open();
SqlDataReader rdr = cmd.ExecuteReader();
var dt = new DataTable();
dt.Load(rdr);
List result = dt.AsEnumerable().ToList();
rdr.Close();
string json = DataTableToJSON(dt);
return json;
}
catch (Exception ex)
{
return ex.Message;
}
}
public string DataTableToJSON(DataTable dt)
{
string JSONString = string.Empty;
string json = JsonConvert.SerializeObject(dt, Formatting.Indented);
return json;
}
Подробнее здесь: https://stackoverflow.com/questions/675 ... en-when-re
JSON TO DATATABLE, вызывая эту ошибку в C# «Неожиданный токен JSON> при чтении DataTable. Ожидаемый startArray, Got Stri ⇐ C#
Место общения программистов C#
1754865878
Anonymous
Я извлекаю код json из API < /p>
Нет проблем с этим < /p>
Выход JSON - эта строка < /p>
\"[\\r\\n {\\r\\n \\\"PtsID\\\": 14061\\r\\n }\\r\\n]\"
< /code>
Но когда я пытаюсь преобразовать это в DataTable < /p>
Использование этой строки кода < /p>
Вот мой код < /p>
DataTable dt1 = (DataTable)JsonConvert.DeserializeObject(json, (typeof(DataTable)));
< /code>
Я получаю эту ошибку < /p>
newtonsoft.json.jsonserializationexception: 'неожиданный токен JSON
при чтении DataTable. Ожидается, что startarray, получил строку. PATH '', Line
1, позиция 46. HttpClient client = new HttpClient();
client.DefaultRequestHeaders.Accept.Add(
new MediaTypeWithQualityHeaderValue("application/json"));
string json = client.GetStringAsync(url).Result;
DataTable dt1 = (DataTable)JsonConvert.DeserializeObject(json, (typeof(DataTable)));
[b] edit [/b]
Я посмотрел этот ответ здесь
Deserialize вложенный набор данных из json string с json.net
и изменил мой код на этот
class MyTableUtilClass
{
public string PtsID { get; set; }
public DataTable Table { get; set; }
}
HttpClient client = new HttpClient();
client.DefaultRequestHeaders.Accept.Add(
new MediaTypeWithQualityHeaderValue("application/json"));
string json = client.GetStringAsync(url).Result;
var myUtil = JsonConvert.DeserializeObject(json);
DataTable myTable = myUtil.Table;
< /code>
Но при достижении этой строки < /p>
var myUtil = JsonConvert.DeserializeObject(json);
< /code>
Я получаю эту ошибку < /p>
newtonsoft.json.jsonserializationexception: 'Ошибка преобразования значения »[
{
" ptsid ": 14061}]" type' encoder.frmcoder+mytabletlclaslclaslclaslclasclc. Path '', Line 1, положение 46. '< /p>
< /blockquote>
, которая является той же ошибкой, которую я получил до .. < /p>
Любое решение? В приложении < /p>
Вот код из API < /p>
[Route("api/SearchSelect")]
public string Get(string P1 = null, string P2 = null, string P3 = null, string P4 = null)
{
SqlConnection conn = new SqlConnection(gDBConn);
SqlCommand cmd = new SqlCommand("SearchSelect", conn);
cmd.CommandTimeout = 0;
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(new SqlParameter("@PtsName", P1));
cmd.Parameters.Add(new SqlParameter("@PtsNo", P2));
cmd.Parameters.Add(new SqlParameter("@RepCode", P3));
cmd.Parameters.Add(new SqlParameter("@RepText", P4));
try
{
conn.Open();
SqlDataReader rdr = cmd.ExecuteReader();
var dt = new DataTable();
dt.Load(rdr);
List result = dt.AsEnumerable().ToList();
rdr.Close();
string json = DataTableToJSON(dt);
return json;
}
catch (Exception ex)
{
return ex.Message;
}
}
public string DataTableToJSON(DataTable dt)
{
string JSONString = string.Empty;
string json = JsonConvert.SerializeObject(dt, Formatting.Indented);
return json;
}
Подробнее здесь: [url]https://stackoverflow.com/questions/67552806/json-to-datatable-causing-this-error-in-c-sharp-unexpected-json-token-when-re[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия