Я хочу составить список из ответа API JSON, как показано для каждого билета в jira, и удалить все дубликаты.
Я могу получить значения для каждого билета, но не могу сделать его списком и удалить из него дубликаты для обработки.
Вот ответ API JSON для каждого билета
response = {
"expand": "renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations",
"id": "1831845",
"self": "https://jira.com/login/rest/api/latest/issue/1845",
"key": "pc-1002",
"fields": {
"customfield_1925": {
"self": "https://jira.com/login/rest/api/2/customFieldOption/1056",
"value": "windows",
"id": "101056"
}
поэтому у меня есть такой скрипт:
import requests, json
tick = """jira: pc-1002,pc-1003,pc-1005
env"""
ticks = tick.replace(' ','').split(':')[1].split('\n')[0].split(',')
print(ticks)
for i in ticks:
url = "https://jira.com/login/rest/api/latest/issue/" + str(i)
print(url)
response = requests.request("GET", url, verify=False)
response = json.loads(response.text)
resp = response['fields']['customfield_1925']['value']
print(resp)
поэтому он печатает все значения, как показано ниже: выход:
окна1 окна2 окна1
Я хочу, чтобы выходные значения были уникальными и, поскольку они могут иметь дубликаты.
Я хотел вывести, как показано ниже
['окна1', 'окна2']






Просто добавьте каждый ответ в список ответов и используйте удобный оператор Python «in», чтобы проверить, есть ли каждый ответ в списке. Что-то вроде:
allResponses = []
for i in ticks:
url = "https://jira.com/login/rest/api/latest/issue/" + str(i)
print(url)
response = requests.request("GET", url, verify=False)
response = json.loads(response.text)
resp = response['fields']['customfield_1925']['value']
if resp not in allResponses:
print(resp)
allResponses.append(resp)
Это прекрасно работает, но значение resp имеет символ Юникода, например [u'test', u'test2'], как удалить эти u'?
Если в начале всегда только одна буква «u», вы можете обрезать первый символ, используя нарезку строки Python. Я думаю, что изменение "resp = response['fields']['customfield_1925']['value']" на "resp = response['fields']['customfield_1925']['value'][1:] должно подойти Это.
он нарезает первую букву, например [u'test', u'test2'], на [u'est', u'est2']
его в основном имеет значение resp как [u'test', u'test2 - test2 - test3'], поэтому он добавляет его как [u'test', u'test2 \u2013 test2 \u2013 test3'] , \u2013 вызывает проблема.
Строковое управление вашими уникальными записями - еще одна проблема, извините, я не мог сделать это сразу - не могли бы вы пометить мой ответ как решение вашей исходной проблемы для этого поста?