Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Неработещ код във VBA Excel

Featured Replies

Имам 4 колони и искам колона D да се сравява с колона M, а колона E да се сравнява с колона N И ако има еднакви числа да се нулират и всичко да се случва с едно кликане на бутонче в Excel,  но немога да обединя кода. Този със сигурност не работи, по отделно работят но незнам как да ги обединя в едно. Бихте ли ми помогнали?

 

Dim x As Range, y As Range, z As Range, q As Range, de As Range

Set x = Range("D1:D20")
Set y = Range("N1:N20")
Set q = Range("E1:E20")
Set z = Range("M1:M20")
Set de = Range("D1:E20")
de.Select
For Each x In Range("D1:D20")
    For Each y In Range("N1:N20")
        For Each z In Range("E1:E20")
            For Each q In Range("M1:M20")
        If x.Value = y.Value Then
            x.Value = 0
            y.Value = 0
        End If
        
         If z.Value = q.Value Then
            z.Value = 0
            q.Value = 0
        End If
        
            Next q
        Next z
    Next y
Next x

Редактирано от ExaFlop (преглед на промените)

Ами помисли малко.

Защо всички цикли са вложени един в друг. Правиш проверките една след друга, две по две, но първо единия, после другия.

И защо е това задаване на стойности на Range в началото, а de поне за момента е излишно, а z и q също.

Dim x As Range, y As Range
For Each x In Range("D1:D20")
   For Each y In Range("M1:M20")
        If x.Value = y.Value Then
            x.Value = 0
            y.Value = 0
        End If
 next y
next x


 For Each x In Range("E1:E20")
  For Each y In Range("N1:N20")   
      If x.Value = y.Value Then
        x.Value = 0
        y.Value = 0
      End If
   Next q
 Next z
 

Редактирано от TRN (преглед на промените)

  • Автор
на 15.05.2017 г. в 8:43, TRN написа:

Ами помисли малко.

Защо всички цикли са вложени един в друг. Правиш проверките една след друга, две по две, но първо единия, после другия.

И защо е това задаване на стойности на Range в началото, а de поне за момента е излишно, а z и q също.

Dim x As Range, y As Range
For Each x In Range("D1:D20")
   For Each y In Range("M1:M20")
        If x.Value = y.Value Then
            x.Value = 0
            y.Value = 0
        End If
 next y
next x


 For Each x In Range("E1:E20")
  For Each y In Range("N1:N20")   
      If x.Value = y.Value Then
        x.Value = 0
        y.Value = 0
      End If
   Next q
 Next z
 

Благодаря много. Не съм писала на Visual Basic, а трябва да направя това и съвсем набързо попрочетох, но ми е трудно. Благодаря, че има хора като вас, които помагат!

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.