Я извлекаю код 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#
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение