1 / 1 / 0
Регистрация: 02.05.2022
Сообщений: 80

TypeError: 'int' object is not subscriptable. Надо высчитать самую высокую зарплату среди Female и Male

07.06.2022, 11:31. Показов 1002. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
data = [['15624510', 'Male', '19', '19000', '0'], ['15810944', 'Male', '35', '20000', '0'], ['15668575', 'Female', '26', '43000', '0'], ['15603246', 'Female', '27', '57000', '0'], ['15804002', 'Male', '19', '76000', '0'], ['15728773', 'Male', '27', '58000', '0'], ['15598044', 'Female', '27', '84000', '0'], ['15694829', 'Female', '32', '150000', '1'], ['15600575', 'Male', '25', '33000', '0'], ['15727311', 'Female', '35', '65000', '0'], ['15570769', 'Female', '26', '80000', '0'], ['15606274', 'Female', '26', '52000', '0'], ['15746139', 'Male', '20', '86000', '0']]

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
import numpy as np
 
def salary_info(data, gender=None):
    print('This statisctics are for Female and Male:')
    lst_1 = []
    for index in range(len(data)):
        if data[index][1] == 'Female':
            
            lst_1.append(index[3])
            salary = np.array(lst_1)
            max_salary = salary.max()
            print('Max salary:', max_salary)
            
        else:
            lst_1.append(index[3])
            salary = np.array(lst_1)
            max_salary = salary.max()
            print('Max salary:', max_salary)
 
 
salary_info(filt_data, gender="Female")
TypeError: 'int' object is not subscriptable
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.06.2022, 11:31
Ответы с готовыми решениями:

TypeError: 'int' object is not subscriptable
a = int(input()) lat = lst = for i in range(a): lst.append(i) if int(i) >= 4: lat.append(i) for i in...

TypeError: 'int' object is not subscriptable
a = b = n = int ( input()) n-=1 for i in range ( 0 , n ): a = int (input()) b = int (input()) for z in range (0 ,n ...

TypeError: 'int' object is not subscriptable
i = l = z = 0 dlina = 0 for l in l: dlina=dlina+l*2 z=z+1 print(dlina, z) Ошибка:

3
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
07.06.2022, 12:35
Лучший ответ Сообщение было отмечено timaKazh как решение

Решение

timaKazh,
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import pandas as pd 
import numpy as np
 
data = [['15624510', 'Male', '19', '19000', '0'], 
        ['15810944', 'Male', '35', '20000', '0'], 
        ['15668575', 'Female', '26', '43000', '0'], 
        ['15603246', 'Female', '27', '57000', '0'], 
        ['15804002', 'Male', '19', '76000', '0'], 
        ['15728773', 'Male', '27', '58000', '0'], 
        ['15598044', 'Female', '27', '84000', '0'], 
        ['15694829', 'Female', '32', '150000', '1'], 
        ['15600575', 'Male', '25', '33000', '0'], 
        ['15727311', 'Female', '35', '65000', '0'], 
        ['15570769', 'Female', '26', '80000', '0'], 
        ['15606274', 'Female', '26', '52000', '0'], 
        ['15746139', 'Male', '20', '86000', '0']]
 
df = pd.DataFrame(data, columns = ['id', 'gender', 'age', 'salary', 'tmp'])
df[['age','salary']] = df[['age','salary']].astype('int32',errors='ignore')
print(df)
 
max_salary_gender = df.groupby('gender')['salary'].max().to_dict()
print(max_salary_gender)
Numpy со строковыми данными "плохо"(медленно) работает, тем более с разными типами данных.
По идее можно создать структурированный массив numpy -> https://pyprog.pro/structured_arrays.html

Добавлено через 8 минут
19-ю строчку можно так:
Python
1
df = df.apply(pd.to_numeric,errors='ignore')
Но, возможно, столбцы "id" и "tmp" в дальнейшем предпочтительно оставить строковыми типами данных...

Добавлено через 19 минут
Ваш исправленный код (вывод статистики группы "Female"):
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
def salary_info(data, gender=None):
    print(f'This statisctics are for {gender}:')
    lst_1, lst_2 = [], []
    for index in range(len(data)):
        if data[index][1] == gender:
            lst_1.append(int(data[index][3]))
    max_salary = max(lst_1)
    print(f'Max salary: {max_salary}')
 
 
filt_data = [['15624510', 'Male', '19', '19000', '0'], 
        ['15810944', 'Male', '35', '20000', '0'], 
        ['15668575', 'Female', '26', '43000', '0'], 
        ['15603246', 'Female', '27', '57000', '0'], 
        ['15804002', 'Male', '19', '76000', '0'], 
        ['15728773', 'Male', '27', '58000', '0'], 
        ['15598044', 'Female', '27', '84000', '0'], 
        ['15694829', 'Female', '32', '150000', '1'], 
        ['15600575', 'Male', '25', '33000', '0'], 
        ['15727311', 'Female', '35', '65000', '0'], 
        ['15570769', 'Female', '26', '80000', '0'], 
        ['15606274', 'Female', '26', '52000', '0'], 
        ['15746139', 'Male', '20', '86000', '0']]
 
salary_info(filt_data, gender="Female")
1
1 / 1 / 0
Регистрация: 02.05.2022
Сообщений: 80
07.06.2022, 12:49  [ТС]
<ipython-input-131-d58761a2e8e4> in salary_info(data, gender)
5 if data[index][1] == gender:
6 lst_1.append(int(data[index][3]))
----> 7 max_salary = max(lst_1)
8 print(f'Max salary: {max_salary}')

ValueError: max() arg is an empty sequence


У меня вот такую ошибку выводит
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
07.06.2022, 13:21
timaKazh, чему равен lst_1?

Добавлено через 3 минуты
Здесь всё ОК
https://www.online-python.com/NWuKOJtAyh
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.06.2022, 13:21
Помогаю со студенческими работами здесь

Ошибка TypeError: 'int' object is not subscriptable
Здравствуйте. Решаю следующую задачу: Дан набор из N целых положительных чисел. Для каждого числа вычисляется сумма двух последних цифр в...

Ошибка TypeError: 'int' object is not subscriptable
b = ]]]] print(a) Вот сам код не понимаю почему выходит ошибка

Выдает ошибку TypeError: 'int' object is not subscriptable
File &quot;C:\Users\nazar\Desktop\6 task module.py&quot;, line 21, in &lt;module&gt; if bag &gt;= max_bag and weight &lt;= max_weight: TypeError: 'int'...

Не могу понять из-за появляется ошибка : TypeError: 'int' object is not subscriptable
https://pastebin.com/raw/f5HEJ0Q2 a, b = map(int, input().split()) v=int(input()) j= * (v + a) h= * (a * b) for i in range(v): ...

В файле query1 найти среди Sales, самую большую зарплату, а среди Research самую маленькую зарплату
В файле query1 найти среди Отдела Sales, самую большую зарплату, а среди Отдела Research самую маленькую зарплату. Нужно через grep всё. Я...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru