Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 22.03.2020
Сообщений: 110

Оптимизация программы

31.03.2023, 04:03. Показов 862. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Обучаюсь программированию.

Есть вот такое задание:

Составить программу на питоне, которая умееет:
1. Выполнять создание и удаление файла. Тип файла - текстовый документ.
2. Умеет изменять все доступные атрибуты безопасности (DACL, ACE) на базе Windows.

Написал следующий код:

Code
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
import win32security
import os
import win32con
#import ntsecuritycon as con
 
 
def create(name):
    open(name, 'tw')
    
 
def remove(name):
    os.remove(name)
 
 
def access():
    target_folder = r"C:\Users\Admin\Desktop\ad"
    print("Введите пользователя или группу:")
    user = input()
    print("Доступные флаги:")
    print("E - Execute file\nR_D - Read Data\nR_A - Read Attributes\nR_E - Read Extended Attributes\nW_D - Write Data\nA_D - Append Data\nW_A - Write Attributes\nW_E - Write Extended Attributes\nD -  Delete\nR_P - Read Permissions\nC_P - Change Permissions\nT_O - Take Ownership\nA_S - Add Subdirectory\n\nR - Read\nW - Write\nRX - Read&Execute\nM - Modify\nF - Full control\n\nclear - очистка всех атрибутов\n")
    print("Введите флаг:")
    
    read_data = 1
    read_attributes = 128
    read_extended_attributes = 8
    write_data = 2
    append_data = 4
    add_subdirectory = 4
    write_attributes = 256
    write_extended_attributes = 16
    delete = 65536
    change_permsission = 262144
    read_permission = 131072
    take_ownership = 524288
    execute = 32
    read_only = 1179785
    write_only = 1048854
    full_access = 2032127
    modify_only = 1245631
    read_and_execute = 1179817
    clear = 0
    
    flags = win32security.OBJECT_INHERIT_ACE | win32security.CONTAINER_INHERIT_ACE
    sd = win32security.GetNamedSecurityInfo(
        target_folder,
        win32security.SE_FILE_OBJECT,
        win32security.DACL_SECURITY_INFORMATION
        )
    dacl = sd.GetSecurityDescriptorDacl()
    
    while True:
        A = input()
        
        if A == "F":
            access_dict = {
                user: 'F'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "R":
            access_dict = {
                user: 'R'
            }
            print("Выполнено")
            print("Что вы хотите сделать?")
            break
        elif A == "M":
            access_dict = {
                user: 'M'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "W":
            access_dict = {
                user: 'W'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "RX":
            access_dict = {
                user: 'RX'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "R_D":
            access_dict = {
                user: 'R_D'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "R_A":
            access_dict = {
                user: 'R_A'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "R_E":
            access_dict = {
                user: 'R_E'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "E":
            access_dict = {
                user: 'E'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "W_D":
            access_dict = {
                user: 'W_D'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "A_D":
            access_dict = {
                user: 'A_D'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "A_S":
            access_dict = {
                user: 'A_S'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "W_A":
            access_dict = {
                user: 'W_A'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "W_E":
            access_dict = {
                user: 'W_E'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "D":
            access_dict = {
                user: 'D'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "C_P":
            access_dict = {
                user: 'C_P'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "R_P":
            access_dict = {
                user: 'R_P'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "T_O":
            access_dict = {
                user: 'T_O'
            }
            print("Выполнено!")
            print("Что вы хотите сделать?")
            break
        elif A == "clear":
            #access_dict = {
              #  user: 'clear'
            #}
           ace_count = dacl.GetAceCount()
           counter = ace_count
           for i in range(0, ace_count): # Удаляем все ACE
                dacl.DeleteAce(0)
            #print("ACE:", ace_count)
            #    print("counter:", counter)
           #     counter -= 1
            #print("Все атрибуты очищены!")
           #break
        else:
            print("Неверный флаг!")
            break
        
    for userName, access in access_dict.items():
        userx, domain, type = win32security.LookupAccountName("", userName)
        if access == "R":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                read_only,
                userx
                )   # Write
        if access == "W":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                write_only,
                userx
                )   # Write
        if access == "F":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                full_access,
                userx
                )   # Full
        if access == "RX":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                read_and_execute,
                userx
                )   # Read and Execute
        if access == "M":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                modify_only,
                userx
                )   # Read and Execute
        if access == "E":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                execute,
                userx
                )   # Read and Execute
        if access == "R_D":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                read_data,
                userx
                )
        if access == "R_A":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                read_attributes,
                userx
                )
        if access == "R_E":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                read_extended_attributes,
                userx
                )
        if access == "W_D":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                write_data,
                userx
                )
        if access == "W_A":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                write_attributes,
                userx
                )
        if access == "W_E":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                write_extended_attributes,
                userx
                )
        if access == "D":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                delete,
                userx
                )
        if access == "R_P":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                read_permission,
                userx
                )
        if access == "C_P":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                change_permsission,
                userx
                )
        if access == "T_O":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                take_ownership,
                userx
                )
        if access == "A_S":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                add_subdirectory,
                userx
                )
        if access == "A_D":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                append_data,
                userx
                )
        if access == "clear":
            dacl.AddAccessAllowedAceEx(
                win32security.ACL_REVISION_DS,
                flags,
                clear,
                userx
                )
           
    win32security.SetNamedSecurityInfo(
        target_folder,
        win32security.SE_FILE_OBJECT,
        win32security.DACL_SECURITY_INFORMATION,
        None,
        None,
        dacl,
        None
    )
 
sv = 0
 
print("Что вы хотите сделать?")
print("1 - создать файл")
print("2 - удалить файл")
print("3 - изменить атрибуты безопасности")
 
while True:
 
    sv = input()
    
    if sv == "1":
        print("Введите имя файла, который необходимо создать")
        name = input()
        create(name)
        print("Выполнено!")
        print("Что вы хотите сделать?")
        print("1 - создать файл")
        print("2 - удалить файл")
        print("3 - изменить атрибуты безопасности")
        print("4 - очистить атрибуты безопасности")
    
    elif sv == "2":
        print("Введите имя файла, который необходимо удалить")
        name = input()
        remove(name)
        print("Выполнено!")
        print("Что вы хотите сделать?")
        print("1 - создать файл")
        print("2 - удалить файл")
        print("3 - изменить атрибуты безопасности")
    
    elif sv == "3":
        access()
    
    else:
        print("Неверно выбранная опция!")
Не могу придумать, как можно этот код упростить или сделать компактным, а также, не понимаю, как можно реализовать введение нескольких атрибутов за 1 раз и как очистить уже имеющиеся атрибуты для указанного пользователя или группы?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.03.2023, 04:03
Ответы с готовыми решениями:

Оптимизация программы
Добрый день, поставлена следующая задача: Выписать все слова, которые являются анаграммами друг для друга, например «замок» и «мазок»....

Оптимизация программы
a = input() d = int(input()) b = list(map(int, a)) e = j = 0 for i in range(len(b)): if(b == 9): c = b = 0 ...

Оптимизация программы с использованием генераторов
На скиллбокс узнал про генераторы, решил протестить. Прога выводит квадраты чисел от 1 ввода до 2. Сделал 2 варианта. Полезен ли в данном...

3
 Аватар для kazak
3602 / 2743 / 355
Регистрация: 11.03.2009
Сообщений: 6,304
31.03.2023, 12:04
Лучший ответ Сообщение было отмечено SirEagle как решение

Решение

Цитата Сообщение от SirEagle Посмотреть сообщение
Не могу придумать, как можно этот код упростить или сделать компактным
Не надо, пусть препод мучается
Примерно так:
Цитата Сообщение от SirEagle Посмотреть сообщение
read_data = 1
read_attributes = 128
read_extended_attributes = 8
write_data = 2
append_data = 4
add_subdirectory = 4
write_attributes = 256
write_extended_attributes = 16
delete = 65536
change_permsission = 262144
read_permission = 131072
take_ownership = 524288
execute = 32
read_only = 1179785
write_only = 1048854
full_access = 2032127
modify_only = 1245631
read_and_execute = 1179817
clear = 0
=>
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
    flags_dict = {
        'R_D': 1,
        'R_A': 128,
        'R_E': 8,
        'W_D': 2,
        'A_D': 4, # здесь нужно проверить значения, у разных флагов должны быть разные значения
        'A_S': 4, # здесь нужно проверить значения, у разных флагов должны быть разные значения
        'W_A': 256,
        'W_E': 16,
        'D': 65536,
        'C_P': 262144,
        'R_P': 131072,
        'T_O': 524288,
        'E': 32,
        'R': 1179785,
        'W': 1048854,
        'F': 2032127,
        'M': 1245631,
        'RX': 1179817,
    }
Цитата Сообщение от SirEagle Посмотреть сообщение
while True:
A = input()
if A == "F":
access_dict = {
user: 'F'
}
print("Выполнено!")
print("Что вы хотите сделать?")
break
...
=>
Python
1
2
3
4
5
6
7
8
9
10
11
    while True:
        A = input()
        access_dict = {
            user: 0
        }
        if A == 'clear':
            pass # Логика для clear
        elif A in flags_dict:
            access_dict[user] += flags_dict[A]
        else:
            print('Bad choice')
Цитата Сообщение от SirEagle Посмотреть сообщение
for userName, access in access_dict.items():
userx, domain, type = win32security.LookupAccountName("", userName)
if access == "R":
dacl.AddAccessAllowedAceEx(
win32security.ACL_REVISION_DS,
flags,
read_only,
userx
) # Write
if access == "W":
=>
Python
1
2
3
4
5
6
7
8
    for userName, access in access_dict.items():
        userx, domain, type = win32security.LookupAccountName("", userName)
        dacl.AddAccessAllowedAceEx(
            win32security.ACL_REVISION_DS,
            flags,
            access,
            userx
        )
0
0 / 0 / 0
Регистрация: 22.03.2020
Сообщений: 110
31.03.2023, 17:51  [ТС]
Code
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import win32security
import os
import win32con
#import ntsecuritycon as con
 
 
def create(name):
    open(name, 'tw')
    
 
def remove(name):
    os.remove(name)
 
 
def access():
    target_folder = r"C:\Users\Admin\Desktop\ad"
    print("Введите пользователя или группу:")
    user = input()
    print("Доступные флаги:")
    print("E - Execute file\nR_D - Read Data\nR_A - Read Attributes\nR_E - Read Extended Attributes\nW_D - Write Data\nA_D - Append Data\nW_A - Write Attributes\nW_E - Write Extended Attributes\nD -  Delete\nR_P - Read Permissions\nC_P - Change Permissions\nT_O - Take Ownership\nA_S - Add Subdirectory\n\nR - Read\nW - Write\nRX - Read&Execute\nM - Modify\nF - Full control\n\nclear - очистка всех атрибутов\n")
    print("Введите флаг:")
    
    flags = win32security.OBJECT_INHERIT_ACE | win32security.CONTAINER_INHERIT_ACE
    sd = win32security.GetNamedSecurityInfo(
        target_folder,
        win32security.SE_FILE_OBJECT,
        win32security.DACL_SECURITY_INFORMATION
        )
    dacl = sd.GetSecurityDescriptorDacl()
    
    flags_dict = {
        'R_D': 1,
        'R_A': 128,
        'R_E': 8,
        'W_D': 2,
        'A_D': 4, # здесь нужно проверить значения, у разных флагов должны быть разные значения
        'A_S': 4, # здесь нужно проверить значения, у разных флагов должны быть разные значения
        'W_A': 256,
        'W_E': 16,
        'D': 65536,
        'C_P': 262144,
        'R_P': 131072,
        'T_O': 524288,
        'E': 32,
        'R': 1179785,
        'W': 1048854,
        'F': 2032127,
        'M': 1245631,
        'RX': 1179817,
    }
    
    while True:
        A = input()
        access_dict = {
            user: 0
        }
        if A == 'done':
            print("Ввод атрибутов завершен!")
            break
        if A == 'clear':
           print("Очистка атрибутов осуществлена!")
           break
        elif A in flags_dict:
            access_dict[user] += flags_dict[A]
            print("Атрибут установлен!")
            print("dq: ", flags_dict[A])
            print("21: ", access_dict[user])
            break
        else:
            print('Неверно выбранный флаг!')
    #
    ace_count = dacl.GetAceCount()
    for i in range(0, ace_count): # Удаляем все ACE
        dacl.DeleteAce(0)
                
    for userName, access in access_dict.items():
        userx, domain, type = win32security.LookupAccountName("", userName)
        dacl.AddAccessAllowedAceEx(
            win32security.ACL_REVISION_DS,
            flags,
            access,
            userx
        )
 
sv = 0
 
print("Что вы хотите сделать?")
print("1 - создать файл")
print("2 - удалить файл")
print("3 - изменить атрибуты безопасности")
 
while True:
 
    sv = input()
    
    if sv == "1":
        print("Введите имя файла, который необходимо создать")
        name = input()
        create(name)
        print("Выполнено!")
        print("Что вы хотите сделать?")
        print("1 - создать файл")
        print("2 - удалить файл")
        print("3 - изменить атрибуты безопасности")
        print("4 - очистить атрибуты безопасности")
    
    elif sv == "2":
        print("Введите имя файла, который необходимо удалить")
        name = input()
        remove(name)
        print("Выполнено!")
        print("Что вы хотите сделать?")
        print("1 - создать файл")
        print("2 - удалить файл")
        print("3 - изменить атрибуты безопасности")
    
    elif sv == "3":
        access()
    
    else:
        print("Неверно выбранная опция!")
Привел вот к такому виду код по Вашему совету, но почему-то права теперь вообще не изменяются для указанного пользователя. Также, я уточнял в теме: как можно производить очистку прав доступа?

Code
1
2
3
    ace_count = dacl.GetAceCount()
    for i in range(0, ace_count): # Удаляем все ACE
        dacl.DeleteAce(0)
Установка вот такого блока кода вообще ни к чему не приводит, но отрабатывает. Права не очищаются. Также пробовал через установку константы нулем, но все равно, ничего не меняется...

Добавлено через 3 часа 3 минуты
Отбой тревоги
Случайно удалил лишнее и не сохранялись новые права поэтому. Огромное спасибо!
0
 Аватар для kazak
3602 / 2743 / 355
Регистрация: 11.03.2009
Сообщений: 6,304
31.03.2023, 19:20
Цитата Сообщение от kazak Посмотреть сообщение
Python
1
access_dict[user] += flags_dict[A]
Тут лучше сложение побитовым ИЛИ заменить, на случай, если один и тот же флаг введут несколько раз, избавит от проблем.
Python
1
access_dict[user] |= flags_dict[A]
Добавлено через 6 минут
Цитата Сообщение от SirEagle Посмотреть сообщение
как можно производить очистку прав доступа?
Не силен в winapi32, но для AddAccessAllowedAceEx вроде есть зеркальный метод AddAccessDeniedAceEx.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.03.2023, 19:20
Помогаю со студенческими работами здесь

Оптимизация программы, определяющей - палиндром число или нет
Данная программа работает правильно, выводит положительное утверждение о палиндромности тогда, когда нужно. Но я думаю, что эту программу...

Оптимизация программы
Подскажите, как можно оптимизировать данную программу? a = int(input()) b = int(input()) count = 0 for x in range(a, b+1): d...

Оптимизация программы для задачи
Есть задача: На промежутке найти количество чисел, которые имеют ровно 3 различных четных делителя Написать программу...

Оптимизация программы, имитирующей меню в ресторане
Добрый день! Подскажите, как можно оптимизировать данный код. Совсем недавно начал знакомиться с PyQT5 и не до конца понимаю...

Типы оптимизация: черная оптимизация, серая оптимизация и белая оптимизация
Много много лет назад, на заре становления профессии "оптимизатора" в какой то умной книжке был создан миф. Это миф о цветовой индефикации...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru