Range

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Range

Сообщение Чудик » 18.12.2004 (Сб) 11:00

Вопрос касается Excel, но, по моему он не относится напрямую к VBA, почему, ниже:
xl.Sheets(1).Range(Cells(Ysel1, Xsel1), Cells(Ysel2, Xsel2)).Select
такая запись проходит в VBA, но когда я пишу это в VB для внешнего управления Excel, выдает ошибку (ошибка определения объекта).
Как это можно обойти? Именно в VB.
Век живи - век учись!
www.detal-plast.narod.ru

GSerg
Шаман
Шаман
 
Сообщения: 14286
Зарегистрирован: 14.12.2002 (Сб) 5:25
Откуда: Магадан

Сообщение GSerg » 18.12.2004 (Сб) 11:02

with xl.Sheets(1)
.Range(.Cells(Ysel1, Xsel1), .Cells(Ysel2, Xsel2)).Select
end with
Как только вы переберёте все варианты решения и не найдёте нужного, тут же обнаружится решение, простое и очевидное для всех, кроме вас

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 18.12.2004 (Сб) 11:02

Попробуй не Cells, а xl.Sheets(1).Cells
Lasciate ogni speranza, voi ch'entrate.

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 18.12.2004 (Сб) 11:03

Ай-ай-ай :) Опять опередил :)
Lasciate ogni speranza, voi ch'entrate.

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 18.12.2004 (Сб) 11:13

Наверное, надо иметь определенный склад ума,
я бы так и не додумался, хотя указанная вами запись логична.
Спасибо!
Век живи - век учись!
www.detal-plast.narod.ru

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 18.12.2004 (Сб) 11:23

Я думаю, что будет не в обиду, если тут проскочит, еще вопрос с той же тематики.
Озадачен, как высветить предварительный просмотр печати листа Excel и чтоб при закрытии этого просмотра сам лист не становился видимым, потому что, как я понимаю, при переключении на предварительный просмотр мы и переключаемся на саму кнмгу.
Но на данный момент даже предварительного просмотра не могу организовать - .PrintPreview - зависает все приложение.
Век живи - век учись!
www.detal-plast.narod.ru

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 18.12.2004 (Сб) 12:07

Не совсем понял, что нужно.
Есть скрытый инстанс Excel. Нужно сделать PrintPreview и отобразить это окно, не отображая окно самого Excel. Так? Думаю, не сделать этого.
Просто делай xl.Visible = True, а затем Preview.
Lasciate ogni speranza, voi ch'entrate.

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 18.12.2004 (Сб) 12:24

В принципе, alibek, ты понял правильно. Если предварительно делать Visible=True, то в самом деле все работает, это решает только первую часть моей сложности, вторая - это как опять скрыть книгу после закрытия предварительного просмотра, так как я не хотел бы представлять пользователю доступ к Excel. Может есть какое-то событие на этот случай? Если это не реально, пожалуйста, дай знать, чтоб я далее просто не мучился и не терял времени. Угу?
Век живи - век учись!
www.detal-plast.narod.ru

GSerg
Шаман
Шаман
 
Сообщения: 14286
Зарегистрирован: 14.12.2002 (Сб) 5:25
Откуда: Магадан

Сообщение GSerg » 18.12.2004 (Сб) 12:51

Попробуй посмотреть, как там происходят у xl события windowactivate/windowdeactivate...
Как только вы переберёте все варианты решения и не найдёте нужного, тут же обнаружится решение, простое и очевидное для всех, кроме вас

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 18.12.2004 (Сб) 13:27

А можно ли из VB перехватывать события Excel? Иначе никак.
Век живи - век учись!
www.detal-plast.narod.ru

GSerg
Шаман
Шаман
 
Сообщения: 14286
Зарегистрирован: 14.12.2002 (Сб) 5:25
Откуда: Магадан

Сообщение GSerg » 18.12.2004 (Сб) 13:31

Дык ну да...
private withevents xl as excel.application :)
Как только вы переберёте все варианты решения и не найдёте нужного, тут же обнаружится решение, простое и очевидное для всех, кроме вас

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 18.12.2004 (Сб) 14:28

Не понял ...
Написал private withevents xl as excel.application в Declarations формы, ниже
Private Sub Workbook_WindowActivate(ByVal Wn As Excel.Window)
MsgBox "1"
End Sub
а собитие не ловиться, в других вариантах вообще ошибки лезут. Не допру ...
Век живи - век учись!
www.detal-plast.narod.ru

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 18.12.2004 (Сб) 14:35

Написал private withevents xl as excel.application ?
Теперь открой список объектов (левый комбобокс) и найди xl. Ну а дальше открывай правый комбобокс и смотри, какие события ты можешь ловить.
Lasciate ogni speranza, voi ch'entrate.

Чудик
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 639
Зарегистрирован: 06.07.2004 (Вт) 12:18
Откуда: г. Егорьевск

Сообщение Чудик » 18.12.2004 (Сб) 15:21

Ребята, мне стыдно ... Туповат немного ... Видно, не вырос пока ...
Век живи - век учись!
www.detal-plast.narod.ru


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: Google-бот и гости: 6

    TopList