Как разобрать доктрину PHP QueryBuilder DateTime от httpresponsemessage до c# datetime?C#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Как разобрать доктрину PHP QueryBuilder DateTime от httpresponsemessage до c# datetime?

Сообщение Anonymous »

Я пытаюсь перенести результат SQL с моего веб-сайта PHP, который я делаю, я делаю с формами Xamarin. Я сделал это, сделав конечную точку API REST в моем приложении PHP и, следовательно, вызывая URL через мое приложение C#. Это возвращает массив JSON с моими результатами. Тем не менее, я не могу найти способ проанализировать объект DateTime, который я получаю в C# DateTime, поскольку он имеет ".00000" за DateTime, от которого я не могу избавиться. < /P>
sql < /strong> < /p>

Код: Выделить всё

$query = $this->createQueryBuilder('c')
->select('partial c.{id, image, title,contentType, createdOn }', 'partial cd.{id, data}', 'partial u.{id, email} ', 'partial ud.{id, screenName, profileImage} ')
->join('c.data', 'cd')
->join('c.user', 'u')
->join('u.data', 'ud')
->andWhere('c.user !=:user')
->setParameters(
array(
'user' => $this->janVanAllemanId
)
)
->orderBy('c.modifiedOn', 'DESC')
->setFirstResult($offset)
->setMaxResults($limit)
->getQuery();

$results = $query->getArrayResult();
< /code>

 json Array < /strong> < /p>

        {
"posts": [
{
"id": 3373,
"contentType": 6,
"createdOn": {
"date": "2019-05-21 14:00:14.000000",
"timezone_type": 3,
"timezone": "Europe/Amsterdam"
},
...

},
{
"id": 3371,
"contentType": 6,
"createdOn": {
"date": "2019-05-18 14:30:09.000000",
"timezone_type": 3,
"timezone": "Europe/Amsterdam"
},
...

}
]
}
Как видите, он возвращает массив с "date" [/b], "Timezone" и " timezone_type ". Я не могу использовать это, чтобы проанализировать его в объект C# DateTime для жизни меня.
postrepository.cs

public class PostRepository : Repository
{
public async Task GetNotifications(int userId, int offset = 0, int limit = 16)
{
string[] queryParams = { "userId=" + userId, "offset=" + offset, "limit=" + limit };
string uri =
RestService.GetApiUrl(UrlExtension.POST_NOTIFICATIONS, queryParams);

List posts = new List();
HttpResponseMessage response = null;
response = await client.GetAsync(uri);

if (response.IsSuccessStatusCode)
{

PostList postList = await response.Content.ReadAsAsync();

posts = postList.Posts;
}

return posts as List;
}
}
< /code>

postlist.cs

public class PostList
{
[JsonProperty("posts")]
public List
Posts { get; set; }
public PostList()
{
}
}
< /code>

*Метод 1:
Через свойство DateTime я попытался починить результат. < /p>

post.cs < /strong> < /p>

...
public class Post
{
[JsonProperty("createdOn")]
public DateTime CreatedOnDateTime{get;set;}
}
< /code>

Это, очевидно, не работает, потому что это не является действительным объектом DateTime. Поэтому я попробовал Jobject и получил ключ «дата», который вы могли бы увидеть выше в моем массиве JSON:

post.cs


...

public class Post
{
public DateTime CreatedOnDateTime {get;set;}
[JsonProperty("createdOn")]
public JObject CreatedOn{
set{
CreatedOnDateTime= DateTime.ParseExact(value["date"].ToString(),
"M/d/yyyy hh:mm",CultureInfo.CreateSpecificCulture("nl-NL"));

}
}
< /code>

он, успешно преобразует Jobjure, но генерирует исключение, говоря, что это не действительная строка для преобразования в объект DateTime! В основном я думаю, что причина, по которой это не работает, заключается в том, что за мои даты магически появляется .00000 в C# DateTime? Я очень ценю вашу помощь!

Подробнее здесь: https://stackoverflow.com/questions/562 ... ssage-to-c
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Как разобрать доктрину PHP QueryBuilder DateTime от httpresponsemessage до c# datetime?
    Anonymous » » в форуме Php
    0 Ответы
    10 Просмотры
    Последнее сообщение Anonymous
  • Как заставить доктрину автоматически заполнять сгенерированные значения для моделирования?
    Anonymous » » в форуме Php
    0 Ответы
    15 Просмотры
    Последнее сообщение Anonymous
  • Используйте доктрину на индивидуальном занятии
    Anonymous » » в форуме Php
    0 Ответы
    14 Просмотры
    Последнее сообщение Anonymous
  • Symfony 4.1: вы запросили несуществующую «доктрину» службы.
    Anonymous » » в форуме Php
    0 Ответы
    15 Просмотры
    Последнее сообщение Anonymous
  • Разобрать строковое представление объекта datetime в datetime
    Anonymous » » в форуме Python
    0 Ответы
    22 Просмотры
    Последнее сообщение Anonymous

Вернуться в «C#»