Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.59/27: Рейтинг темы: голосов - 27, средняя оценка - 4.59
0 / 0 / 0
Регистрация: 22.03.2012
Сообщений: 6

Ускорение работы макроса

22.03.2012, 10:59. Показов 5377. Ответов 22
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день всем!!!
Прошу помочь с нижеприведенным макросом на предмет ускорения его работы.Расчет делает минут 30-40 для
1500 строчек.Для работы необходимо считать около 30 000 строк.Буду очень признателен за советы и за примеры улучшений кода)))

---------
Visual Basic
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
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
Sub ochistka()
''очистка данных
    Worksheets("выход").Range("Y5:MF1600").ClearContents
    Worksheets("выход").Range("Y5:MF1600").Interior.Pattern = xlNone
    Worksheets("занятость").Range("E3:LL1600").ClearContents
End Sub
 
Sub NLR()
ochistka
Application.Calculation = xlCalculationManual
Application.ScreenUpdating = False
Application.EnableEvents = False
t_nachalo_prozedur = Timer
 
k = 0 '' коэффициент для последней операции (изготовление за день до вывоза)
k1 = 0  ''сдвижка в днях
nomer_posl_rabochego = 26
 
For i = 5 To 1600
     If Sheets("выход").Cells(i, 8).Value = "+" Then '' проверить является ли операция последней
     
      plan_perioda_diap = Sheets("выход").Range(Cells(i, 346), Cells(i, 385)).Value
      plan_perioda = Application.WorksheetFunction.Sum(plan_perioda_diap)
      narast_proizvedeno_diap = Sheets("выход").Range(Cells(i, 25), Cells(i, 344)).Value
      narast_proizvedeno = Application.WorksheetFunction.Sum(narast_proizvedeno_diap)
     
     If plan_perioda > narast_proizvedeno Then
      For j = 346 To 385
       normativ_igzotovleniya = Sheets("выход").Cells(i, 10).Value
        ostatok_na_1_chislo = Sheets("выход").Cells(i, 23).Value
        ''посчитать сколько потребность и сколько изготовлено по графику
        narast_potrbnost_diap = Sheets("выход").Range(Cells(i, 346), Cells(i, j)).Value
        narast_potrbnost = Application.WorksheetFunction.Sum(narast_potrbnost_diap)
        narast_proizvedeno_diap = Sheets("выход").Range(Cells(i, 25), Cells(i, 344)).Value
        narast_proizvedeno = Application.WorksheetFunction.Sum(narast_proizvedeno_diap)
   
          If narast_potrbnost > narast_proizvedeno + ostatok_na_1_chislo Then ''если нарастающая потребность > произведено нарасатающим + остаток на 1-е число
     
          zifra = narast_potrbnost - narast_proizvedeno - ostatok_na_1_chislo
          
          If zifra > 0.0001 Then
          trud_izg_cifri = (Sheets("выход").Cells(i, j).Value * normativ_igzotovleniya)
          partia_zapuska = Sheets("выход").Cells(i, 20).Value
          
          If zifra > partia_zapuska Then
          zifra = Application.WorksheetFunction.RoundUp(zifra / partia_zapuska, 0) * partia_zapuska
          
          ''ограничение по плану месяца
          If zifra + narast_proizvedeno > plan_perioda Then
          zifra = plan_perioda - narast_proizvedeno
          End If
                
          Else
                    
          zifra = partia_zapuska
          ''ограничение по плану месяца
          If zifra + narast_proizvedeno > plan_perioda Then
          zifra = plan_perioda - narast_proizvedeno
          End If
          ''
          End If
          
          inv_stanka = Sheets("выход").Cells(i, 4).Value
     
          
          k1 = 0
          If zifra > 0.0001 Then   '' если не все детали сделали
      
          '' идем в следующиий день
          '' определяем в какой день нужно пойти
            den = Sheets("выход").Cells(3, j).Value - k - k1
            If den > 0 Then
               '' проверить  станок
              For den = den To 1 Step -1
              For b = 7 To 0 Step -1
              For a = 382 To 600
                If zifra > 0.0001 Then
                
                If inv_stanka = Sheets("занятость").Cells(a, 1).Value Then  '' тот ли станок
                      
                      If den > 0 Then
                      If Sheets("занятость").Cells(a, (den * 12) - b).Value < 60 Then  '' если свободен станок
                      
                      For g = 3 To nomer_posl_rabochego
                     If zifra > 0.0001 Then
                     pers = Sheets("занятость").Cells(g, 1).Value
                     kol_rabochih = Application.WorksheetFunction.CountA(Cells(i, 12), Cells(i, 13), Cells(i, 14), Cells(i, 15), Cells(i, 16), Cells(i, 17))
                     For f = 0 To kol_rabochih
                     If zifra > 0.0001 Then
                     If Sheets("выход").Cells(i, 12 + f).Value = pers Then ''если тот
                     virabotka = Sheets("занятость").Cells(g, 4).Value
                         
                         If ((Sheets("занятость").Cells(g, (den * 12) - b).Value) < (60 * virabotka)) Then      ''если свободен перс
                      
                      If den > 0 Then
                                                     
                          If zifra > 0.0001 Then
                          
                          brigada = Sheets("выход").Cells(i, 9).Value
                         
                             '' занести минимум между свободным временем и временем изготовлнеия(прибавив ранее занесенное) в трудоемкости
                             zaneseno_vremia = Sheets("занятость").Cells(a, (den * 12) - b).Value  '' уже была загрузка на станке
                             svobodnoe_vremya_stanka = (60 * virabotka) - zaneseno_vremia
                             
                             If svobodnoe_vremya_stanka < 0 Then
                             svobodnoe_vremya_stanka = 0
                             End If
                             
                             zaneseno_vremia_pers = Sheets("занятость").Cells(g, (den * 12) - b).Value ''был загружен перс
                             svobodnoe_vremya_pers = (60 * virabotka) - zaneseno_vremia_pers
                                                          
                             If zaneseno_vremia_pers < 0 Then
                             zaneseno_vremia_pers = 0
                             End If
                            '' занести загрузку станка
                             zanesti_min = Application.WorksheetFunction.Min(svobodnoe_vremya_stanka, ((normativ_igzotovleniya * zifra) / virabotka), svobodnoe_vremya_pers)
                             
                             ''проверяем на необходимость наладки
                             If zanesti_min > 0.0001 Then ''если есть что заносить
                             If Sheets("выход").Cells(i, 3).Value <> 1 Then ''если налаживается
                             If Sheets("выход").Cells(i, (24 + den * 8 - b)).Value = 0 Then '' если  не делали в этот же час
                              If b = 7 And den <> 1 Then              ''если час первый               ''делали ли в предыдущий час?
                           
                               If Sheets("выход").Cells(i, (24 + ((den - 1) * 8) - 0)).Value > 0 Then ''проверяем предыдущий день
                               nalagen = 1         ''ставим индикатор наладки(делалась)
                               Else: nalagen = 2 '' не делалась(необходимо налаживать)
                               End If
                              Else       ''если час не первый
                               If Sheets("выход").Cells(i, (24 + den * 8 - b - 1)).Value > 0 Then ''делали ли в предыдущий час?
                               nalagen = 1         ''ставим индикатор наладки(делалась)
                               Else: nalagen = 2 '' не делалась(необходимо налаживать)
                            
                               End If
                              End If
                             Else: nalagen = 1
                             End If
                             Else: nalagen = 1 ''если не налаживается
                                                        
                             End If
                             End If
                     
                       
                             ''не налаживается
                             If nalagen = 1 Then
                             ''
                             Sheets("занятость").Cells(a, (4 + den * 8) - b).Value = zanesti_min + zaneseno_vremia
                            '' занести персонал
                            zanesti_min_pers = Application.WorksheetFunction.Min(svobodnoe_vremya_pers, ((normativ_igzotovleniya * zifra) / virabotka), svobodnoe_vremya_stanka)
                            Sheets("занятость").Cells(g, (4 + den * 8) - b).Value = zanesti_min_pers + zaneseno_vremia_pers
                             ''занести штуки в выход
                            zanesti_min_shtuk = (zanesti_min * virabotka / normativ_igzotovleniya)
                            Sheets("выход").Cells(i, 24 + (den * 8) - b).Value = Sheets("выход").Cells(i, 24 + (den * 8) - b).Value + zanesti_min_shtuk
                             '' отнять занесенное
                            zifra = zifra - zanesti_min_shtuk
                        
                       Else
                            
                      If zanesti_min > 0.0001 Then ''если есть что заносить
                            For Z = 1516 To 1524
                            If brigada = Sheets("занятость").Cells(Z, 1).Value Then
                      
                            If Sheets("занятость").Cells(Z, (4 + den * 8) - b).Value < 60 * Sheets("занятость").Cells(Z, 4).Value Then
                          
                            Sheets("занятость").Cells(Z, (4 + den * 8) - b).Value = Sheets("занятость").Cells(Z, (4 + den * 8) - b).Value + 20
                            Sheets("выход").Cells(i, 24 + (den * 8) - b).Interior.ColorIndex = 4
                          
                            Sheets("занятость").Cells(a, (4 + den * 8) - b).Value = zanesti_min + zaneseno_vremia
                            '' занести персонал
                            zanesti_min_pers = Application.WorksheetFunction.Min(svobodnoe_vremya_pers, ((normativ_igzotovleniya * zifra) / virabotka), svobodnoe_vremya_stanka)
                            Sheets("занятость").Cells(g, (4 + den * 8) - b).Value = zanesti_min_pers + zaneseno_vremia_pers
                            ''занести штуки в выход
                            zanesti_min_shtuk = (zanesti_min * virabotka / normativ_igzotovleniya)
                            Sheets("выход").Cells(i, 24 + (den * 8) - b).Value = Sheets("выход").Cells(i, 24 + (den * 8) - b).Value + zanesti_min_shtuk
                             '' отнять занесенное
                            zifra = zifra - zanesti_min_shtuk
                          
                     
                            End If
                            End If
                            Next Z
                            End If
                          '--------------------------------
                          End If
                         End If
                      End If
                     End If
                      
                        End If
                       End If
                       Next f
                      End If
                      Next g
                     End If
                     End If
            
                End If
              End If
              Next a
             Next b
            Next den
                         
            
            End If
          End If
     
      
        End If
        End If
      Next j
   
    
  End If
  End If
Next i
MsgBox ((Timer - t_nachalo_prozedur) / 60)
End Sub
 
Sub NLR_prom()
 
Application.Calculation = xlCalculationManual
Application.ScreenUpdating = False
Application.EnableEvents = False
 
For n = 17 To 1 Step -1     ''для уровня от 20 до 1 шагом -1
For i = 5 To 1600      '' для строк от 5 по 700
 
kol_rabochih = Application.WorksheetFunction.CountA(Cells(i, 12), Cells(i, 13), Cells(i, 14), Cells(i, 15), Cells(i, 16), Cells(i, 17))
nomer_posl_rabochego = 26
 
partia_zapuska = Sheets("выход").Cells(i, 20).Value
inv_stanka = Sheets("выход").Cells(i, 4).Value
primenaemost = Sheets("выход").Cells(i, 11).Value
 
level = Sheets("выход").Cells(i, 7).Value      ''уровень равен
If level = n Then '' проверить уровень
If Sheets("выход").Cells(i, 8).Value <> "+" Then ''если операция не последняя
 
normativ_igzotovleniya = Sheets("выход").Cells(i, 10).Value
normativ_igzotovleniya_uzla = Sheets("выход").Cells(i + 1, 10).Value
normativ_igzotovleniya_partii = Application.WorksheetFunction.RoundUp(normativ_igzotovleniya * partia_zapuska * 1.3 / 60, 0)
'''---------------------------------------------------------------------------------------------------'''
''-------------------------------------------------------------
''от начала '
 
''---------------------нулим----------------------------
''------------------------------------------------------
j = 0
e = 0
ostatok_na_1_chislo = 0
narast_potrbnost = 0
narast_proizvedeno = 0
q = 0
m = 0
plan_na_chas = 0
t = 0
p = 0
igz_na_chas = 0
u = 0
partia_zapuska = 0
inv_stanka = 0
primenaemost = 0
zifra = 0
plan_perioda = 0
trud_izg_cifri = 0
a = 0
den = 0
b = 0
e = 0
g = 0
f = 0
brigada = 0
nalagen = 0
zaneseno_vremia = 0
svobodnoe_vremya_stanka = 0
zaneseno_vremia_pers = 0
svobodnoe_vremya_pers = 0
zanesti_min = 0
zanesti_min_pers = 0
zanesti_min_shtuk = 0
Z = 0
''-----------------------------------------------------------------
''-----------------------------------------------------------------
 
     For j = 1 To 40     ''для дня от 40 до 1 шагом -1
     For e = 7 To 0 Step -1          ''для часов от 0 до 7
 
     plan_perioda_diap = Sheets("выход").Range(Cells(i + 1, 25), Cells(i + 1, 344)).Value
     plan_perioda = Application.WorksheetFunction.Sum(plan_perioda_diap)
     
   ostatok_na_1_chislo = Sheets("выход").Cells(i, 23).Value
   narast_potrbnost = 0
   narast_proizvedeno = 0
   ''-----
   If (24 + 8 * j - e + normativ_igzotovleniya_partii) > 344 Then ''чтобы не вылезти за пределы расчета
   normativ_igzotovleniya_partii = 344 - 24 + 8 * j - e
   End If
   narast_potrbnost_diap = Sheets("выход").Range(Cells(i + 1, 25), Cells(i + 1, 24 + 8 * j - e + normativ_igzotovleniya_partii)).Value
   narast_potrbnost = Application.WorksheetFunction.Sum(narast_potrbnost_diap)
  
   If narast_potrbnost > 0 Then
   narast_proizvedeno_diap = Sheets("выход").Range(Cells(i, 25), Cells(i, 344)).Value
   narast_proizvedeno = Application.WorksheetFunction.Sum(narast_proizvedeno_diap)
   End If
   ''-----
   ''--------------------------------------------------
133 If narast_potrbnost > narast_proizvedeno + ostatok_na_1_chislo Then ''если нарастающая потребность > произведено нарасатающим + остаток на 1-е число
      
          zifra = narast_potrbnost - narast_proizvedeno - ostatok_na_1_chislo
          trud_izg_cifri = (zifra * normativ_igzotovleniya)
          partia_zapuska = Sheets("выход").Cells(i, 20).Value
          
          If zifra > partia_zapuska Then
          zifra = Application.WorksheetFunction.RoundUp(zifra / partia_zapuska, 0) * partia_zapuska
      
          ''ограничение по плану месяца
            If zifra + narast_proizvedeno > plan_perioda Then
            zifra = plan_perioda - narast_proizvedeno
            End If
          ''
            Else
            zifra = partia_zapuska
           ''ограничение по плану месяца
            If zifra + narast_proizvedeno > plan_perioda Then
            zifra = plan_perioda - narast_proizvedeno
            End If
          ''
          End If
          
          inv_stanka = Sheets("выход").Cells(i, 4).Value
     
233         If zifra > 0.0001 Then '' если не все детали сделали
      
          '' идем в следующиий день
          '' определяем в какой день нужно пойти
              For den = j To 1 Step -1
              For b = 7 To 0 Step -1
              ''ПРоверка на планирование операций после изготовления следцющих
                              
                              narast_proizvedeno_na_datu_diap = Sheets("выход").Range(Cells(i, 25), Cells(i, 24 + (den * 8) - b)).Value
                              narast_proizvedeno_na_datu = Application.WorksheetFunction.Sum(narast_proizvedeno_na_datu_diap)
                                                            
                              narast_proizvedeno_na_datu_verh_diap = Sheets("выход").Range(Cells(i + 1, 25), Cells(i + 1, 24 + (den * 8) - b)).Value
                              narast_proizvedeno_na_datu_verh = Application.WorksheetFunction.Sum(narast_proizvedeno_na_datu_verh_diap)
                              If (narast_proizvedeno_na_datu) < narast_proizvedeno_na_datu_verh Then
                              GoTo 65033
                              
                              End If
                            
              '' проверить  станок
              For a = 382 To 600
433                If zifra > 0.0001 Then
533                If inv_stanka = Sheets("занятость").Cells(a, 1).Value Then  '' тот ли станок
                        
                         ''-------------проверка чтоб не планировать раньше сл.операции в один и тот же день
                      If den = j Then
                      If b <= e Then '?????????????
                      GoTo 65033
                      End If
                      End If
                 
733                      If den > 0 Then
                       If zifra > 0.0001 Then
                     
                        ''---------------------------
833                      If Sheets("занятость").Cells(a, (4 + den * 8) - b).Value < 60 Then '' если свободен станок
                      
                      For g = 3 To nomer_posl_rabochego
933                     If zifra > 0 Then
                     pers = Sheets("занятость").Cells(g, 1).Value
                     For f = 0 To kol_rabochih
1033                     If zifra > 0.0001 Then
1133                     If Sheets("выход").Cells(i, 12 + f).Value = pers Then ''если тот
                     virabotka = Sheets("занятость").Cells(g, 4).Value
                         
1233                        If ((Sheets("занятость").Cells(g, (4 + den * 8) - b).Value) < (60 * virabotka)) Then    ''если свободен перс
                      
1333                      If den > 0 Then
                                                      
1433                          If zifra > 0.0001 Then
                          
                          brigada = Sheets("выход").Cells(i, 9).Value
                   
                             '' занести минимум между свободным временем и временем изготовлнеия(прибавив ранее занесенное) в трудоемкости
                             zaneseno_vremia = Sheets("занятость").Cells(a, (4 + den * 8) - b).Value '' уже была загрузка на станке
                             svobodnoe_vremya_stanka = (60 * virabotka) - zaneseno_vremia
                             
                             If svobodnoe_vremya_stanka < 0 Then
                             svobodnoe_vremya_stanka = 0
                             End If
                             
                             zaneseno_vremia_pers = Sheets("занятость").Cells(g, (4 + den * 8) - b).Value ''был загружен перс
                             svobodnoe_vremya_pers = (60 * virabotka) - zaneseno_vremia_pers
                                                          
                             If zaneseno_vremia_pers < 0 Then
                             zaneseno_vremia_pers = 0
                             End If
                             '
                             zanesti_min = Application.WorksheetFunction.Min(svobodnoe_vremya_stanka, ((normativ_igzotovleniya * zifra) / virabotka), svobodnoe_vremya_pers)
                            
                            ''проверяем на необходимость наладки
                             If zanesti_min > 0.0001 Then ''если есть что заносить
                             If Sheets("выход").Cells(i, 3).Value <> 1 Then ''если налаживается
                             If Sheets("выход").Cells(i, (24 + den * 8 - b)).Value = 0 Then '' если  не делали в этот же час
                              If b = 7 And den <> 1 Then              ''если час первый               ''делали ли в предыдущий час?
                           
                               If Sheets("выход").Cells(i, (24 + ((den - 1) * 8) - 0)).Value > 0 Then ''проверяем предыдущий день
                               nalagen = 1         ''ставим индикатор наладки(делалась)
                               Else: nalagen = 2 '' не делалась(необходимо налаживать)
                               End If
                              Else       ''если час не первый
                               If Sheets("выход").Cells(i, (24 + den * 8 - b - 1)).Value > 0 Then ''делали ли в предыдущий час?
                               nalagen = 1         ''ставим индикатор наладки(делалась)
                               Else: nalagen = 2 '' не делалась(необходимо налаживать)
                       
                               End If
                              End If
                             Else: nalagen = 1
                             End If
                             Else: nalagen = 1 ''если не налаживается
                                                        
                             End If
                             End If
                       
                              ''не налаживается
                             If nalagen = 1 Then
                             
                             Sheets("занятость").Cells(a, (4 + den * 8) - b).Value = zanesti_min + zaneseno_vremia
                            
                            '' занести персонал
                            
                            zanesti_min_pers = Application.WorksheetFunction.Min(svobodnoe_vremya_pers, ((normativ_igzotovleniya * zifra) / virabotka), svobodnoe_vremya_stanka)
                            Sheets("занятость").Cells(g, (4 + den * 8) - b).Value = zanesti_min_pers + zaneseno_vremia_pers
            
                             ''занести штуки в выход
                            zanesti_min_shtuk = (zanesti_min * virabotka / normativ_igzotovleniya)
                            Sheets("выход").Cells(i, 24 + (den * 8) - b).Value = Sheets("выход").Cells(i, 24 + (den * 8) - b).Value + zanesti_min_shtuk
                             '' отнять занесенное
                            zifra = zifra - zanesti_min_shtuk
                          '' -------------------------------
                            ''-------------------------------'
                            '------------------------------------------
                            ''теперь проверяем на возможность наладки
                            Else
                                                       
                          If zanesti_min > 0.0001 Then ''если есть что заносить
                            
                            For Z = 1516 To 1524
                            If brigada = Sheets("занятость").Cells(Z, 1).Value Then
                            
                            If Sheets("занятость").Cells(Z, (4 + den * 8) - b).Value < 60 * Sheets("занятость").Cells(Z, 4).Value Then
                          
                            Sheets("занятость").Cells(Z, (4 + den * 8) - b).Value = Sheets("занятость").Cells(Z, (4 + den * 8) - b).Value + 20
                            Sheets("выход").Cells(i, 24 + (den * 8) - b).Interior.ColorIndex = 4
                          
                            Sheets("занятость").Cells(a, (4 + den * 8) - b).Value = zanesti_min + zaneseno_vremia
                            '' занести персонал
                            zanesti_min_pers = Application.WorksheetFunction.Min(svobodnoe_vremya_pers, ((normativ_igzotovleniya * zifra) / virabotka), svobodnoe_vremya_stanka)
                            Sheets("занятость").Cells(g, (4 + den * 8) - b).Value = zanesti_min_pers + zaneseno_vremia_pers
                            ''занести штуки в выход
                            zanesti_min_shtuk = (zanesti_min * virabotka / normativ_igzotovleniya)
                            Sheets("выход").Cells(i, 24 + (den * 8) - b).Value = Sheets("выход").Cells(i, 24 + (den * 8) - b).Value + zanesti_min_shtuk
                             '' отнять занесенное
                            zifra = zifra - zanesti_min_shtuk
                            End If
                            End If
                            Next Z
                            End If
                        ''--------------------------------
                        ''--------------------------------
                        ''--------------------------------
                             End If
140033                       End If
130033                      End If
120033                     End If
                      
110033                        End If
100033                       End If
                       Next f
90033                      End If
                      Next g
80033                     End If
                        End If
70033                     End If
                    
     
50033                End If
40033                End If
                  
                  Next a
65033             Next b
                Next den
 
20033             End If
10033            End If
          ''''------------------------------------
 
Next e
Next j
 
''----------------------------------------------------------------------------------------------
''----------------------------------------------------------------------------------------------
''----------------------------------------------------------------------------------------------
''----------------------------------------------------------------------------------------------
'-от начала'
End If
End If
 
Next i
Next n
 
End Sub
 
Sub NLR_Ves()
NLR
NLR_prom
End Sub
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.03.2012, 10:59
Ответы с готовыми решениями:

Ускорение работы макроса (преобразование данных к нужному формату)
Добрый день! в программировании на VBA недавно, а поэтому подозреваю, что подход к написанию кода во многом нубский. Для своей задачи...

Ускорение макроса
Всем привет. У меня есть огромный макрос делающий динамические отчеты, т.е. есть база, он ее открывает, немного изменяет под себя, делает...

Ускорение макроса удаления ячеек
Добрый вечер! Очень нужна помощь. Подскажите,как ускорить макрос, который удаляет все неокрашенные ячейки из диапазона: Dim c As Range ...

22
 Аватар для Alex77755
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
22.03.2012, 12:38
единственное предложение - считать всё в массивы (одной строкой) и работать.
Потом вывалить готовые результаты на лист.
Без файла примера плохо вникать в работу макроса
0
735 / 203 / 11
Регистрация: 23.06.2011
Сообщений: 440
22.03.2012, 12:51
Очевидно, вам остро требуется база данных. Я пока не разобрался в коде, но мне кажется, что хранить данные столь сложной структуры и работать с ними на листе Excel нельзя. Надо сделать структуру в том же Access, поместить туда данные, обрабатывать их с помощью SQL-запроса и готовый результат уже выгружать в Excel.
0
 Аватар для coderxx
469 / 183 / 16
Регистрация: 25.02.2012
Сообщений: 418
Записей в блоге: 2
22.03.2012, 16:49
Цитата Сообщение от kolamba1986 Посмотреть сообщение
Буду очень признателен за советы и за примеры улучшений кода)))
Не использовать Goto.
Вообще, это код какую функцию делает? Можеть быть есть другие решение для этой задачи.
0
 Аватар для Alex77755
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
22.03.2012, 17:34
1500 это количество чего?
У тебя 7 вложенных циклов.
В каждом происходит чтение и запись в ячейки. Это самая длительная операция.
Надо считывать в массивы и кое что загонять в словари.
Например самый внутренний цикл
Visual Basic
1
For f = 0 To kol_rabochih
Зачем его гонять миллионы раз? Проще загнать рабочих в словарь и обращаться непосредственно к нужному
Имеются ненужные условия:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
              For a = 382 To 600
433              If zifra > 0.0001 Then
533                  If inv_stanka = Sheets("занятость").Cells(a, 1).Value Then  '' тот ли станок
                         ''-------------проверка чтоб не планировать раньше сл.операции в один и тот же день
                         If den = j Then
                              If b <= e Then '?????????????
                                    GoTo 65033
                              End If
                         End If
733                      If den > 0 Then
                               If zifra > 0.0001 Then
К чему последнее условие? Оно разве не дублирует вторую строку?

Добавлено через 2 минуты
Лучше приложи образцы что есть и что надо получить
0
 Аватар для mc-black
2786 / 718 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
23.03.2012, 14:02
1. +1 к идее загнать все в массив и с ним работать
2. WorksheetFunction - формулы рабочего листа не должны многократно пересчитываться в цикле, если они считают одно и то же. Посчитал один раз, сохранил результат (в переменную, в массив) и дальше используешь многократно результат значения из переменной, из массива.
3. Бывает, что меняешь данные на листе внутри таблицы, а на каждом шаге цикла пересчитываются куча формул в зависимых ячейках. Во многие макросы, не вникая в код делаю 2 вставки (в начале до работы и в конце - после работы):
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Sub Sample()
    ' Здесь объявления переменных
    
    ' В начале
    Application.ScreenUpdating = False
    Application.EnableEvents = False
    Application.Calculation = xlCalculationManual
    
    ' Здесь основные действия макроса
    
    ' В конце
    Application.ScreenUpdating = True
    Application.EnableEvents = True
    Application.Calculation = xlCalculationAutomatic
End Sub
4. Используем Option Explicit, явно задаем типы переменных, избегаем по возможности типа Variant
0
735 / 203 / 11
Регистрация: 23.06.2011
Сообщений: 440
23.03.2012, 14:08
Цитата Сообщение от mc-black Посмотреть сообщение
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
 
Sub Sample()
' Здесь объявления переменных
' В начале
'<...>
 Application.Calculation = xlCalculationManual
'<...>
' В конце
'<...>
 Application.Calculation = xlCalculationAutomatic
End Sub
Это плохая, очень плохая идея. Надо так:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
 
Sub Sample()
 ' Здесь объявления переменных
 Dim iCalculation as Integer
 ' В начале
 '<...>
 iCalculation=Application.Calculation
 Application.Calculation = xlCalculationManual
 '<...>
 ' В конце
 '<...>
 Application.Calculation = iCalculation
End Sub
0
 Аватар для mc-black
2786 / 718 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
23.03.2012, 14:15
Gibboustooth,
ну пусть будет по Вашему, сохранили настройку по умолчанию, потом её восстановили, более умно. Хотя большинство пользователей привыкло и не задумывается никогда, что автоматический расчет формул можно отключить и ничего не пересчитается разве что как по F9. Минус обоих вариантов - если макрос навернется на пол пути, скажем, из-за Application Error, то оба варианта привещдут к потере изначальной настройки Excel, чем и череват обычно этот метод.
0
 Аватар для KoGG
5641 / 1623 / 418
Регистрация: 23.12.2010
Сообщений: 2,433
Записей в блоге: 1
23.03.2012, 15:05
Цитата Сообщение от Сталин И.В. Посмотреть сообщение
Малой кровью, на чужой территории ...
С учетом отсутствия исходного файла, не зная максимальную размерность массивов и тип рабочих переменных, максимум что могу сделать это:
Visual Basic
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
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
Option Explicit
 
Sub ochistka()
''очистка данных
    Worksheets("выход").Range("Y5:MF1600").ClearContents
    Worksheets("выход").Range("Y5:MF1600").Interior.Pattern = xlNone
    Worksheets("занятость").Range("E3:LL1600").ClearContents
End Sub
 
Sub NLR()
    Dim nalagen As Byte
 
    Dim i%, j%, Den%, b%, a%, g%, f%, Z%
    Dim Den8%, Den12minusB%, Den8plus16%, Den8plus4minusB%, Den8plus24minusB%
    Dim nomer_posl_rabochego%, k%, k1%, kol_rabochih%, brigada%
    
    Dim inv_stanka&
    
    Dim virabotka!
    Dim normativ_igzotovleniya_DEL_virabotka!
    Dim virabotka_DEL_normativ_igzotovleniya!
    Dim t_nachalo_prozedur!, plan_perioda!, narast_proizvedeno!, normativ_igzotovleniya!
    Dim ostatok_na_1_chislo!, narast_potrbnost!, zifra!, partia_zapuska!, trud_izg_cifri!
    Dim zaneseno_vremia!, svobodnoe_vremya_stanka!, zaneseno_vremia_pers!, svobodnoe_vremya_pers!
    Dim zanesti_min!, zanesti_min_pers!, zanesti_min_shtuk!
 
    Dim plan_perioda_diap As Range, narast_proizvedeno_diap As Range, narast_potrbnost_diap As Range
    
    Dim pers As Variant
    
    Application.Calculation = xlCalculationManual
    Application.ScreenUpdating = False
    Application.EnableEvents = False
    t_nachalo_prozedur = Timer
    
    Call ochistka
 
    k = 0 '' коэффициент для последней операции (изготовление за день до вывоза)
    k1 = 0  ''сдвижка в днях
    nomer_posl_rabochego = 26
 
For i = 5 To 1600
  If Sheets("выход").Cells(i, 8).Value = "+" Then '' проверить является ли операция последней
    '+++###
    Set plan_perioda_diap = Sheets("выход").Range(Cells(i, 346), Cells(i, 385))
    plan_perioda = Application.WorksheetFunction.Sum(plan_perioda_diap)
    Set narast_proizvedeno_diap = Sheets("выход").Range(Cells(i, 25), Cells(i, 344))
    narast_proizvedeno = Application.WorksheetFunction.Sum(narast_proizvedeno_diap)
    '+++###
    If plan_perioda > narast_proizvedeno Then
        '+++###
        normativ_igzotovleniya = Sheets("выход").Cells(i, 10).Value
        ostatok_na_1_chislo = Sheets("выход").Cells(i, 23).Value
        partia_zapuska = Sheets("выход").Cells(i, 20).Value
        inv_stanka = Sheets("выход").Cells(i, 4).Value
        brigada = Sheets("выход").Cells(i, 9).Value
        kol_rabochih = Application.WorksheetFunction.CountA(Cells(i, 12), Cells(i, 13), Cells(i, 14), Cells(i, 15), Cells(i, 16), Cells(i, 17))
        '+++###
        For j = 346 To 385
        '==================================
            'normativ_igzotovleniya = Sheets("выход").Cells(i, 10).Value
            'ostatok_na_1_chislo = Sheets("выход").Cells(i, 23).Value
            ''посчитать сколько потребность и сколько изготовлено по графику
            Set narast_potrbnost_diap = Sheets("выход").Range(Cells(i, 346), Cells(i, j))
            narast_potrbnost = Application.WorksheetFunction.Sum(narast_potrbnost_diap)
            'Set narast_proizvedeno_diap = Sheets("выход").Range(Cells(i, 25), Cells(i, 344))
            'narast_proizvedeno = Application.WorksheetFunction.Sum(narast_proizvedeno_diap)
           If narast_potrbnost > narast_proizvedeno + ostatok_na_1_chislo Then ''если нарастающая потребность > произведено нарасатающим + остаток на 1-е число
                  zifra = narast_potrbnost - narast_proizvedeno - ostatok_na_1_chislo
                  If zifra > 0.0001 Then
                      trud_izg_cifri = (Sheets("выход").Cells(i, j).Value * normativ_igzotovleniya)
                      'partia_zapuska = Sheets("выход").Cells(i, 20).Value
                      If zifra > partia_zapuska Then
                          'zifra = Application.WorksheetFunction.RoundUp(zifra / partia_zapuska, 0) * partia_zapuska
                          zifra = Fix(zifra / partia_zapuska + 0.999999) * partia_zapuska
                          ''ограничение по плану месяца
                          If zifra + narast_proizvedeno > plan_perioda Then
                              zifra = plan_perioda - narast_proizvedeno
                          End If
                      Else
                        zifra = partia_zapuska
                        ''ограничение по плану месяца
                        If zifra + narast_proizvedeno > plan_perioda Then
                          zifra = plan_perioda - narast_proizvedeno
                        End If
                        ''
                      End If
                      'inv_stanka = Sheets("выход").Cells(i, 4).Value
                      'k1 = 0
                      If zifra > 0.0001 Then   '' если не все детали сделали
                           '' идем в следующиий день
                           '' определяем в какой день нужно пойти
                             Den = Sheets("выход").Cells(3, j).Value - k - k1
                             If Den > 0 Then
                                '' проверить  станок
                                For Den = Den To 1 Step -1
                                    Den8 = Den * 8
                                    Den8plus16 = Den8 + 16
'>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
     For b = 7 To 0 Step -1
            Den8plus4minusB = Den8 + 4 - b
            Den8plus24minusB = Den8 + 24 - b
            Den12minusB = Den * 12 - b
            For a = 382 To 600
                If zifra > 0.0001 Then
                    If inv_stanka = Sheets("занятость").Cells(a, 1).Value Then  '' тот ли станок
                        If Den > 0 Then
                            If Sheets("занятость").Cells(a, Den12minusB).Value < 60 Then  '' если свободен станок
For g = 3 To nomer_posl_rabochego
'+++++++++++++++++++++++++++++++++++
    If zifra > 0.0001 Then
        pers = Sheets("занятость").Cells(g, 1).Value
        'kol_rabochih = Application.WorksheetFunction.CountA(Cells(i, 12), Cells(i, 13), Cells(i, 14), Cells(i, 15), Cells(i, 16), Cells(i, 17))
        For f = 0 To kol_rabochih
        ']]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]
            If zifra > 0.0001 Then
                If Sheets("выход").Cells(i, 12 + f).Value = pers Then ''если тот
                     virabotka = Sheets("занятость").Cells(g, 4).Value
                     '+++###
                     normativ_igzotovleniya_DEL_virabotka = normativ_igzotovleniya / virabotka
                     virabotka_DEL_normativ_igzotovleniya = virabotka / normativ_igzotovleniya
                     '+++###
                     If ((Sheets("занятость").Cells(g, Den12minusB).Value) < (60 * virabotka)) Then      ''если свободен перс
                            If Den > 0 Then
                                                       
                                If zifra > 0.0001 Then
                                    'brigada = Sheets("выход").Cells(i, 9).Value
                                    '' занести минимум между свободным временем и временем изготовлнеия(прибавив ранее занесенное) в трудоемкости
                                    zaneseno_vremia = Sheets("занятость").Cells(a, Den12minusB).Value  '' уже была загрузка на станке
                                    svobodnoe_vremya_stanka = (60 * virabotka) - zaneseno_vremia
                                    If svobodnoe_vremya_stanka < 0 Then
                                        svobodnoe_vremya_stanka = 0
                                    End If
                                    zaneseno_vremia_pers = Sheets("занятость").Cells(g, Den12minusB).Value ''был загружен перс
                                    svobodnoe_vremya_pers = (60 * virabotka) - zaneseno_vremia_pers
                                    If zaneseno_vremia_pers < 0 Then
                                        zaneseno_vremia_pers = 0
                                    End If
                                   '' занести загрузку станка
                                    zanesti_min = myMin(svobodnoe_vremya_stanka, (zifra * normativ_igzotovleniya_DEL_virabotka), svobodnoe_vremya_pers)
                                    ''проверяем на необходимость наладки
                                    If zanesti_min > 0.0001 Then ''если есть что заносить
                                         If Sheets("выход").Cells(i, 3).Value <> 1 Then ''если налаживается
                                              If Sheets("выход").Cells(i, Den8plus24minusB).Value = 0 Then '' если  не делали в этот же час
                                                If b = 7 And Den <> 1 Then              ''если час первый               ''делали ли в предыдущий час?
                                                  If Sheets("выход").Cells(i, Den8plus16).Value > 0 Then  ''проверяем предыдущий день
                                                     nalagen = 1     ''ставим индикатор наладки(делалась)
                                                  Else: nalagen = 2  '' не делалась(необходимо налаживать)
                                                  End If
                                                Else       ''если час не первый
                                                     If Sheets("выход").Cells(i, (Den8plus4minusB - 1)).Value > 0 Then ''делали ли в предыдущий час?
                                                          nalagen = 1 ''ставим индикатор наладки(делалась)
                                                     Else: nalagen = 2 '' не делалась(необходимо налаживать)
                                                     End If
                                                End If
                                              Else: nalagen = 1
                                              End If
                                         Else: nalagen = 1 ''если не налаживается
                                         End If
                                    End If
                                     ''не налаживается
                                    If nalagen = 1 Then
                                        ''
                                         Sheets("занятость").Cells(a, Den8plus4minusB).Value = zanesti_min + zaneseno_vremia
                                        '' занести персонал
                                        zanesti_min_pers = myMin(svobodnoe_vremya_pers, (zifra * normativ_igzotovleniya_DEL_virabotka), svobodnoe_vremya_stanka)
                                        Sheets("занятость").Cells(g, Den8plus4minusB).Value = zanesti_min_pers + zaneseno_vremia_pers
                                         ''занести штуки в выход
                                        zanesti_min_shtuk = (zanesti_min * virabotka_DEL_normativ_igzotovleniya)
                                        Sheets("выход").Cells(i, Den8plus24minusB).Value = Sheets("выход").Cells(i, Den8plus24minusB).Value + zanesti_min_shtuk
                                         '' отнять занесенное
                                        zifra = zifra - zanesti_min_shtuk
                                    Else
                                        If zanesti_min > 0.0001 Then ''если есть что заносить
'<<---------<<-------------<<---------<<-------<<
For Z = 1516 To 1524
    If brigada = Sheets("занятость").Cells(Z, 1).Value Then
        If Sheets("занятость").Cells(Z, Den8plus4minusB).Value < 60 * Sheets("занятость").Cells(Z, 4).Value Then
        
            Sheets("занятость").Cells(Z, Den8plus4minusB).Value = Sheets("занятость").Cells(Z, Den8plus4minusB).Value + 20
            Sheets("выход").Cells(i, Den8plus24minusB).Interior.ColorIndex = 4
            
            Sheets("занятость").Cells(a, Den8plus4minusB).Value = zanesti_min + zaneseno_vremia
            '' занести персонал
            'zanesti_min_pers = Application.WorksheetFunction.Min(svobodnoe_vremya_pers, ((normativ_igzotovleniya * zifra) / virabotka), svobodnoe_vremya_stanka)
            zanesti_min_pers = myMin(svobodnoe_vremya_pers, (zifra * normativ_igzotovleniya_DEL_virabotka), svobodnoe_vremya_stanka)
            Sheets("занятость").Cells(g, Den8plus4minusB).Value = zanesti_min_pers + zaneseno_vremia_pers
            ''занести штуки в выход
            'zanesti_min_shtuk = (zanesti_min * virabotka / normativ_igzotovleniya)
            zanesti_min_shtuk = zanesti_min * virabotka_DEL_normativ_igzotovleniya
            Sheets("выход").Cells(i, Den8plus24minusB).Value = Sheets("выход").Cells(i, Den8plus24minusB).Value + zanesti_min_shtuk
             '' отнять занесенное
            zifra = zifra - zanesti_min_shtuk
        
        End If
    End If
Next Z
'<<---------<<-------------<<---------<<-------<<
                                         End If
                                    '--------------------------------
                                    End If
                            End If
                        End If
                    End If
 
                End If
            End If
        ']]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]
        Next f
    End If
'+++++++++++++++++++++++++++++++++++
Next g
                            End If
                        End If
            
                    End If
              End If
         Next a
    Next b
'>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
Next Den
                             End If
                       End If
                 End If
            End If
        '=================
        Next j
    End If
  End If
Next i
Application.Calculation = xlCalculationAutomatic
Application.ScreenUpdating = True
Application.EnableEvents = True
MsgBox ((Timer - t_nachalo_prozedur) / 60)
End Sub
 
'[] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] []
'[]                                                                                                    []
'[]                                              NLR_prom                                              []
'[]                                                                                                    []
'[] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] [] []
Sub NLR_prom()
    Dim nalagen As Byte
    
    Dim n%, i%, i1%, j%, e%, Den%, b%, a%, g%, f%, Z%, Level%
    Dim Den8%, Den12minusB%, Den8plus16%, Den8plus4minusB%, Den8plus24minusB%
    Dim nomer_posl_rabochego%, k1%, brigada%, kol_rabochih%
    
    Dim inv_stanka&
    
    Dim virabotka!
    Dim normativ_igzotovleniya_DEL_virabotka!
    Dim virabotka_DEL_normativ_igzotovleniya!
    Dim t_nachalo_prozedur!, plan_perioda!, narast_proizvedeno!, normativ_igzotovleniya!
    Dim ostatok_na_1_chislo!, narast_potrbnost!, zifra!
    'Dim q!, m!, T!, p!, u!
    Dim plan_na_chas!, igz_na_chas!, partia_zapuska!, primenaemost!, trud_izg_cifri!
    Dim zaneseno_vremia!, svobodnoe_vremya_stanka!, zaneseno_vremia_pers!
    Dim svobodnoe_vremya_pers!, zanesti_min!, zanesti_min_pers!, zanesti_min_shtuk!
    Dim normativ_igzotovleniya_uzla!, normativ_igzotovleniya_partii!
    Dim narast_proizvedeno_na_datu!, narast_proizvedeno_na_datu_verh!
 
    Dim pers As Variant
 
    Dim plan_perioda_diap As Range, narast_proizvedeno_na_datu_diap As Range
    Dim narast_proizvedeno_diap As Range
    Dim narast_proizvedeno_na_datu_verh_diap As Range, narast_potrbnost_diap As Range
    
    Application.Calculation = xlCalculationManual
    Application.ScreenUpdating = False
    Application.EnableEvents = False
   
    nomer_posl_rabochego = 26
 
For n = 17 To 1 Step -1     ''для уровня от 20 до 1 шагом -1
    For i = 5 To 1600      '' для строк от 5 по 700
        Level = Sheets("выход").Cells(i, 7).Value      ''уровень равен
        If Level = n Then '' проверить уровень
            If Sheets("выход").Cells(i, 8).Value <> "+" Then ''если операция не последняя
                i1 = i + 1
                kol_rabochih = Application.WorksheetFunction.CountA(Cells(i, 12), Cells(i, 13), Cells(i, 14), Cells(i, 15), Cells(i, 16), Cells(i, 17))
                inv_stanka = Sheets("выход").Cells(i, 4).Value
                primenaemost = Sheets("выход").Cells(i, 11).Value
                brigada = Sheets("выход").Cells(i, 9).Value
                normativ_igzotovleniya = Sheets("выход").Cells(i, 10).Value
                normativ_igzotovleniya_uzla = Sheets("выход").Cells(i1, 10).Value
                'normativ_igzotovleniya_partii = Application.WorksheetFunction.RoundUp(normativ_igzotovleniya * partia_zapuska * 1.3 / 60, 0)
                normativ_igzotovleniya_partii = Fix(normativ_igzotovleniya * partia_zapuska * 1.3 / 60 + 0.999999)
                '+++###
                inv_stanka = Sheets("выход").Cells(i, 4).Value
                partia_zapuska = Sheets("выход").Cells(i, 20).Value
                '+++###
                '''---------------------------------------------------------------------------------------------------'''
                ''от начала '
                ''---------------------нулим----------------------------
                j = 0
                e = 0
                ostatok_na_1_chislo = 0
                narast_potrbnost = 0
                narast_proizvedeno = 0
                'q = 0
                'm = 0
                plan_na_chas = 0
                'T = 0
                'p = 0
                igz_na_chas = 0
                'u = 0
                partia_zapuska = 0
                inv_stanka = 0
                primenaemost = 0
                zifra = 0
                plan_perioda = 0
                trud_izg_cifri = 0
                a = 0
                Den = 0
                b = 0
                e = 0
                g = 0
                f = 0
                brigada = 0
                nalagen = 0
                zaneseno_vremia = 0
                svobodnoe_vremya_stanka = 0
                zaneseno_vremia_pers = 0
                svobodnoe_vremya_pers = 0
                zanesti_min = 0
                zanesti_min_pers = 0
                zanesti_min_shtuk = 0
                Z = 0
                ''-----------------------------------------------------------------
                ''-----------------------------------------------------------------
                For j = 1 To 40     ''для дня от 40 до 1 шагом -1
                    For e = 7 To 0 Step -1          ''для часов от 0 до 7
                    '}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}
                        'plan_perioda_diap = Sheets("выход").Range(Cells(i1, 25), Cells(i1, 344)).Value
                        'plan_perioda = Application.WorksheetFunction.Sum(plan_perioda_diap)
                        Set plan_perioda_diap = Sheets("выход").Range(Cells(i1, 25), Cells(i1, 344))
                        plan_perioda = Application.WorksheetFunction.Sum(plan_perioda_diap)
                        ostatok_na_1_chislo = Sheets("выход").Cells(i, 23).Value
                        narast_potrbnost = 0
                        narast_proizvedeno = 0
                        ''-----
                        If (24 + 8 * j - e + normativ_igzotovleniya_partii) > 344 Then ''чтобы не вылезти за пределы расчета
                             normativ_igzotovleniya_partii = 344 - 24 + 8 * j - e
                        End If
                        Set narast_potrbnost_diap = Sheets("выход").Range(Cells(i1, 25), Cells(i1, 24 + 8 * j - e + normativ_igzotovleniya_partii))
                        narast_potrbnost = Application.WorksheetFunction.Sum(narast_potrbnost_diap)
                        
                        If narast_potrbnost > 0 Then
                             Set narast_proizvedeno_diap = Sheets("выход").Range(Cells(i, 25), Cells(i, 344))
                             narast_proizvedeno = Application.WorksheetFunction.Sum(narast_proizvedeno_diap)
                        End If
                        ''-----
                        ''--------------------------------------------------
                        If narast_potrbnost > narast_proizvedeno + ostatok_na_1_chislo Then ''если нарастающая потребность > произведено нарасатающим + остаток на 1-е число
                              
                            zifra = narast_potrbnost - narast_proizvedeno - ostatok_na_1_chislo
                            trud_izg_cifri = (zifra * normativ_igzotovleniya)
                            'partia_zapuska = Sheets("выход").Cells(i, 20).Value
                            If zifra > partia_zapuska Then
                                'zifra = Application.WorksheetFunction.RoundUp(zifra / partia_zapuska, 0) * partia_zapuska
                                zifra = Fix(zifra / partia_zapuska + 0.999999) * partia_zapuska
                                ''ограничение по плану месяца
                                If zifra + narast_proizvedeno > plan_perioda Then
                                    zifra = plan_perioda - narast_proizvedeno
                                End If
                            Else
                                zifra = partia_zapuska
                                ''ограничение по плану месяца
                                If zifra + narast_proizvedeno > plan_perioda Then
                                    zifra = plan_perioda - narast_proizvedeno
                                End If
                            End If
                            'inv_stanka = Sheets("выход").Cells(i, 4).Value
                            If zifra > 0.0001 Then '' если не все детали сделали
                            '' идем в следующиий день
                            '' определяем в какой день нужно пойти
For Den = j To 1 Step -1
'-------==========--------===========-----------=========
    Den8 = Den * 8
    Den8plus16 = Den8 + 16
    For b = 7 To 0 Step -1
        Den8plus4minusB = Den8 + 4 - b
        Den8plus24minusB = Den8 + 24 - b
        Den12minusB = Den * 12 - b
        ''ПРоверка на планирование операций после изготовления следцющих
        Set narast_proizvedeno_na_datu_diap = Sheets("выход").Range(Cells(i, 25), Cells(i, Den8plus24minusB))
        narast_proizvedeno_na_datu = Application.WorksheetFunction.Sum(narast_proizvedeno_na_datu_diap)
        
        Set narast_proizvedeno_na_datu_verh_diap = Sheets("выход").Range(Cells(i1, 25), Cells(i1, Den8plus24minusB))
        narast_proizvedeno_na_datu_verh = Application.WorksheetFunction.Sum(narast_proizvedeno_na_datu_verh_diap)
        
        If (narast_proizvedeno_na_datu) < narast_proizvedeno_na_datu_verh Then
            GoTo nextB
        End If
        '' проверить  станок
        For a = 382 To 600
            If zifra > 0.0001 Then
                If inv_stanka = Sheets("занятость").Cells(a, 1).Value Then  '' тот ли станок
                ''-------------проверка чтоб не планировать раньше сл.операции в один и тот же день
                If Den = j Then
                    If b <= e Then '?????????????
                       GoTo nextB
                    End If
                End If
                If Den > 0 Then
                    If zifra > 0.0001 Then
                        ''---------------------------
                        If Sheets("занятость").Cells(a, Den8plus4minusB).Value < 60 Then '' если свободен станок
For g = 3 To nomer_posl_rabochego
'---{}------{}--------{}--------{}---------{}-----{}--------{}--------{}---------{}
    If zifra > 0 Then
        pers = Sheets("занятость").Cells(g, 1).Value
        For f = 0 To kol_rabochih
            If zifra > 0.0001 Then
                If Sheets("выход").Cells(i, 12 + f).Value = pers Then ''если тот
                    virabotka = Sheets("занятость").Cells(g, 4).Value
                    '+++###
                    normativ_igzotovleniya_DEL_virabotka = normativ_igzotovleniya / virabotka
                    virabotka_DEL_normativ_igzotovleniya = virabotka / normativ_igzotovleniya
                    '+++###
                    If ((Sheets("занятость").Cells(g, Den8plus4minusB).Value) < (60 * virabotka)) Then    ''если свободен перс
                        If Den > 0 Then
                            If zifra > 0.0001 Then
'                                brigada = Sheets("выход").Cells(i, 9).Value
                                '' занести минимум между свободным временем и временем изготовлнеия(прибавив ранее занесенное) в трудоемкости
                                zaneseno_vremia = Sheets("занятость").Cells(a, Den8plus4minusB).Value '' уже была загрузка на станке
                                svobodnoe_vremya_stanka = (60 * virabotka) - zaneseno_vremia
                                If svobodnoe_vremya_stanka < 0 Then
                                    svobodnoe_vremya_stanka = 0
                                End If
                                zaneseno_vremia_pers = Sheets("занятость").Cells(g, Den8plus4minusB).Value ''был загружен перс
                                svobodnoe_vremya_pers = (60 * virabotka) - zaneseno_vremia_pers
                                If zaneseno_vremia_pers < 0 Then
                                   zaneseno_vremia_pers = 0
                                End If
                                zanesti_min = myMin(svobodnoe_vremya_stanka, (zifra * normativ_igzotovleniya_DEL_virabotka), svobodnoe_vremya_pers)
                                ''проверяем на необходимость наладки
                                If zanesti_min > 0.0001 Then ''если есть что заносить
                                   If Sheets("выход").Cells(i, 3).Value <> 1 Then ''если налаживается
                                      If Sheets("выход").Cells(i, Den8plus24minusB).Value = 0 Then '' если  не делали в этот же час
                                           If b = 7 And Den <> 1 Then              ''если час первый               ''делали ли в предыдущий час?
                                             If Sheets("выход").Cells(i, Den8plus16).Value > 0 Then ''проверяем предыдущий день
                                                  nalagen = 1   ''ставим индикатор наладки(делалась)
                                             Else: nalagen = 2 '' не делалась(необходимо налаживать)
                                             End If
                                           Else       ''если час не первый
                                             If Sheets("выход").Cells(i, (Den8plus24minusB - 1)).Value > 0 Then ''делали ли в предыдущий час?
                                                  nalagen = 1    ''ставим индикатор наладки(делалась)
                                             Else: nalagen = 2 '' не делалась(необходимо налаживать)
                                             End If
                                           End If
                                      Else: nalagen = 1
                                      End If
                                   Else: nalagen = 1 ''если не налаживается
                                   End If
                                End If
                                 ''не налаживается
                                If nalagen = 1 Then
                                    Sheets("занятость").Cells(a, Den8plus4minusB).Value = zanesti_min + zaneseno_vremia
                                    '' занести персонал
                                    zanesti_min_pers = myMin(svobodnoe_vremya_pers, (zifra * normativ_igzotovleniya_DEL_virabotka), svobodnoe_vremya_stanka)
                                    Sheets("занятость").Cells(g, Den8plus4minusB).Value = zanesti_min_pers + zaneseno_vremia_pers
                                    ''занести штуки в выход
                                    zanesti_min_shtuk = (zanesti_min * virabotka_DEL_normativ_igzotovleniya)
                                    Sheets("выход").Cells(i, Den8plus24minusB).Value = Sheets("выход").Cells(i, Den8plus24minusB).Value + zanesti_min_shtuk
                                    '' отнять занесенное
                                    zifra = zifra - zanesti_min_shtuk
                                    '' -------------------------------
                                    ''-------------------------------'
                                    ''теперь проверяем на возможность наладки
                                Else
                                    If zanesti_min > 0.0001 Then ''если есть что заносить
For Z = 1516 To 1524
'#########################################
    If brigada = Sheets("занятость").Cells(Z, 1).Value Then
        If Sheets("занятость").Cells(Z, Den8plus4minusB).Value < 60 * Sheets("занятость").Cells(Z, 4).Value Then
            Sheets("занятость").Cells(Z, Den8plus4minusB).Value = Sheets("занятость").Cells(Z, Den8plus4minusB).Value + 20
            Sheets("выход").Cells(i, Den8plus24minusB).Interior.ColorIndex = 4
            Sheets("занятость").Cells(a, Den8plus4minusB).Value = zanesti_min + zaneseno_vremia
            '' занести персонал
            zanesti_min_pers = myMin(svobodnoe_vremya_pers, (zifra * normativ_igzotovleniya_DEL_virabotka), svobodnoe_vremya_stanka)
            Sheets("занятость").Cells(g, Den8plus4minusB).Value = zanesti_min_pers + zaneseno_vremia_pers
            ''занести штуки в выход
            zanesti_min_shtuk = (zanesti_min * virabotka_DEL_normativ_igzotovleniya)
            Sheets("выход").Cells(i, Den8plus24minusB).Value = Sheets("выход").Cells(i, Den8plus24minusB).Value + zanesti_min_shtuk
             '' отнять занесенное
            zifra = zifra - zanesti_min_shtuk
        End If
    End If
'#########################################
Next Z
                                    End If
                                End If
                            End If
                        End If
                    End If
                End If
            End If
        Next f
    End If
'---{}------{}--------{}--------{}---------{}-----{}--------{}--------{}---------{}
Next g
                            End If
                        End If
                    End If
                End If
            End If
        Next a
nextB: Next b
'-------==========--------===========-----------=========
Next Den
                            End If
                        End If
                    '}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}
                    Next e
                Next j
                ''----------------------------------------------------------------------------------------------
                '-от начала'
            End If
        End If
     
    Next i
Next n
Application.Calculation = xlCalculationAutomatic
Application.ScreenUpdating = True
Application.EnableEvents = True
End Sub
 
 
Sub NLR_Ves()
    NLR
    NLR_prom
End Sub
 
 
Function myMin(Chislo1 As Single, Chislo2 As Single, Chislo3 As Single) As Single
    myMin = Chislo1
    If Chislo2 < myMin Then myMin = Chislo2
    If Chislo3 < myMin Then myMin = Chislo3
End Function
Должно работать быстрее.
kolamba1986, сообщите на сколько ускорилась работа.
0
23.03.2012, 15:14

Не по теме:

Цитата Сообщение от mc-black Посмотреть сообщение
Минус обоих вариантов - если макрос навернется на пол пути, скажем, из-за Application Error, то оба варианта привещдут к потере изначальной настройки Excel, чем и череват обычно этот метод.
Ага, особенно печально, если это была настройка Application.DisplayAlerts. Легким движенем руки можно попрощаться с результатами работы за день.

0
0 / 0 / 0
Регистрация: 22.03.2012
Сообщений: 6
26.03.2012, 10:38  [ТС]
Цитата Сообщение от Alex77755 Посмотреть сообщение
единственное предложение - считать всё в массивы (одной строкой) и работать.
Потом вывалить готовые результаты на лист.
Без файла примера плохо вникать в работу макроса
Добрый день!
Приложил рабочий файл.
если возможно то по-подробнее опишите как затем работать с массивом.
0
0 / 0 / 0
Регистрация: 22.03.2012
Сообщений: 6
26.03.2012, 10:43  [ТС]
что то не зацепилось вложение
Вложения
Тип файла: rar пример.rar (1.06 Мб, 24 просмотров)
0
0 / 0 / 0
Регистрация: 22.03.2012
Сообщений: 6
26.03.2012, 11:09  [ТС]
Alex77755

1500 это количество строк которые необходимо распланировать по графику.
на примере for f необходимо гонять миллион раз т.к. для каждой детали необходимо понять кто ее будет делать.
образцы приложил.надеюсь дополнят картину

Добавлено через 18 минут
Цитата Сообщение от KoGG Посмотреть сообщение
С учетом отсутствия исходного файла, не зная максимальную размерность массивов и тип рабочих переменных, максимум что могу сделать это:

Должно работать быстрее.
kolamba1986, сообщите на сколько ускорилась работа.
к сожалению код перестал работать корректно и время на пересчет ушло в бесконечность(((((
0
 Аватар для KoGG
5641 / 1623 / 418
Регистрация: 23.12.2010
Сообщений: 2,433
Записей в блоге: 1
26.03.2012, 23:50
Все переменные занес в массивы. Убрал еще несколько лишних условий.
Время выполнения макроса NLR - считанные секунды, NLR_prom - 15 минут.
В исходном коде имеются ошибки в адресации, при работе с массивами это вызывало ошибки выхода за границы массивов. Такие области я пометил комментариями с лидирующими знаками !!!
Вложения
Тип файла: rar Kolamba1986.rar (1,006.1 Кб, 15 просмотров)
0
 Аватар для KoGG
5641 / 1623 / 418
Регистрация: 23.12.2010
Сообщений: 2,433
Записей в блоге: 1
27.03.2012, 14:00
Время работы:
NLR - 0 мин. 55 сек.
NLR_prom - 5 мин. 08 сек.

Оптимизирован алгоритм суммирования
переменных:
plan_perioda
narast_potrbnost
narast_proizvedeno
narast_proizvedeno_na_datu
narast_proizvedeno_na_datu_verh
с введением дополнительных массивов:
mProizvedenoSum(1597)
mProizvedenoSumNakop(1597, 320)

Прежние замечания (метки !!!) в силе.

(Система: Windows 7, Офис 2007, ПроцессорIntel(R) Core(TM) i7 CPU 930 @ 2.80GHz, 2801 МГц, ядер: 4, логических процессоров: 8, RAM 4,00 ГБ)
Вложения
Тип файла: zip Kolamba1986.zip (1.04 Мб, 15 просмотров)
0
 Аватар для KoGG
5641 / 1623 / 418
Регистрация: 23.12.2010
Сообщений: 2,433
Записей в блоге: 1
27.03.2012, 15:38
поправил новое суммирование в NLR.
NLR выполняется за 0 мин . 02 сек.
Вложения
Тип файла: zip Kolamba1986.zip (1.04 Мб, 14 просмотров)
1
 Аватар для KoGG
5641 / 1623 / 418
Регистрация: 23.12.2010
Сообщений: 2,433
Записей в блоге: 1
27.03.2012, 17:24
Изменено исправление зоны ошибки размерности в NLR_prom:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
For j = 1 To 40     ''для дня от 40 до 1 шагом -1
    For E = 7 To 0 Step -1          ''для часов от 0 до 7
    '}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}
        'Set plan_perioda_diap = Sheets("выход").Range(Sheets("выход").Cells(i1, 25), Sheets("выход").Cells(i1, 344))
        'plan_perioda = Application.WorksheetFunction.Sum(plan_perioda_diap)
        'plan_perioda = MySum(mProizvedeno, i1, 1, i1, 320)
        plan_perioda = mProizvedenoSum(i1)
        'narast_potrbnost = 0
        'narast_proizvedeno = 0
        ''-----
'                        If (24 + 8 * j - E + normativ_igzotovleniya_partii) > 344 Then ''чтобы не вылезти за пределы расчета
'                               normativ_igzotovleniya_partii = 344 - 24 + 8 * j - E
'                        End If
        normativ_igz_part_p8JmE = 8 * j - E + normativ_igzotovleniya_partii
        If normativ_igz_part_p8JmE > 320 Then ''чтобы не вылезти за пределы расчета
'!!! Следующая строка вызывает ошибку размерности массива
'!!!        normativ_igzotovleniya_partii = 320 - 24 + 8 * j - E
'!!!  Исправлено на
            'normativ_igzotovleniya_partii = 320 - (24 + 8 * j - E)
            normativ_igzotovleniya_partii = 320 - (8 * j - E)
Вложения
Тип файла: zip Kolamba1986.zip (1.04 Мб, 13 просмотров)
1
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18033 / 7736 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
27.03.2012, 23:47
Искусство

Не по теме:

А как сделать такую фишку, ярлычки на авторазворот скрытых колонок, как у ТС?

0
 Аватар для Alex77755
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
28.03.2012, 00:02
Почитай про группировку
0
0 / 0 / 0
Регистрация: 22.03.2012
Сообщений: 6
28.03.2012, 17:51  [ТС]
макрос NLR считается корректно за исключением потерянных 7-х знаков после запятой.
где-то нужно поменять тип переменной?
а вот со вторым NLR_prom незадача:
цифры считаются некорректно; не все значения раскладываются по графику как должны были бы.
Пока не понял почему так.Слишком неузнаваяемо поменян код))))))))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.03.2012, 17:51
Помогаю со студенческими работами здесь

Ускорение работы макросов
Заметил одну очень интересную особенность, хотелось бы с вами посоветоваться по ней. Есть лог файл, например 1мб, и есть макрос,...

Автозаполнение ячеек, ускорение работы
Здравствуйте, подскажите, пожалуйста как можно сделать авто заполнение ячеек как можно удобнее и быстрее. В столбце B...

Оптимизация работы макроса
Ребят всех с наступающим поздравляю! Ребят, написал программу, работает быстро, не тормозит. Начал проверять в реальных рабочих...

Последовательность работы макроса
Дорогие друзья, ответьте на казалось бы глупый вопрос. Почему при срабатывании макроса выполняется код в том числе из другого Private...

Завершение работы макроса
Сегодня при отладке макроса в экселе 2007 заметил интересную фишку. при некоторых действиях макрос просто прекращает работу без ошибок и...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru