RUS  ENG 

Алексей Демин (Все сообщения пользователя)

Выбрать дату в календареВыбрать дату в календаре

Страницы: 1 2 След.
Наименование слоя в переменную в SQL запросе
 
Дмитрий Озеров, подскажите пожалуйста, еще по этой теме. Мне нужно сделать поиск в выделенной области в нескольких слоях.
Что то типа такого. Еще пробовал использовать charindex вместо like.
Код
SEL ECT z.sys, z.[Наименование], z.[Категория строения]
fr om [zdaniya_soorujeniya_trial_1] as z, sa
where z.geometry.within([sa].geometry)
and z.[Наименование] like '%билей%'

UNI ON 
(sel ect x.sys, x.[Наименование узла], x.[Адрес узла ввода]
fr om [Electronnaya_model_PEM_trial_1] as x, sa
where x.geometry.within([sa].geometry) and x.typeid = 3
and x.[Наименование узла] like '%билей%')

UNI ON 
(sel ect c.sys, c.[Наименование узла], c.[Адрес узла ввода]
fr om [ts_sushp_zim] as c, sa
wh ere c.geometry.within([sa].geometry) and c.typeid = 3
and c.[Наименование узла] like '%билей%')
Проблемы тут 2:
1) Нужно в 3-х местах исправлять строку поиска ( '%билей%' ), каждый раз для нового поиска. Я хочу естественно делать это один раз. Пробовал делать так:

Код
Declare @qwe char(100);
set @qwe = 'билей';
SEL ECT z.sys, z.[Наименование], z.[Категория строения]
fr om [zdaniya_soorujeniya_trial_1] as z, sa
where z.geometry.within([sa].geometry)
and z.[Наименование] like @qwe

Это не работает. Const тоже пробовал. Как позже выяснилось, если просто написать:
Код
Declare @qwe char(100);
set @qwe = 'билей';
SEL ECT @qwe
В ответе будет - билей. Но вот если написать допустим

Код
Declare @qwe char(100);
set @qwe = 'билей';
SEL ECT @qwe, z.sys
fr om [layer] as z

в ответе помимо сисов выдаст столбец '@qwe'. Это и есть первая проблема, не понимаю как это работает.

2) Допустим можно потерпеть и исправлять строку для поиска в трех местах, ответ выдает правильно, но тут нюанс. Если в ответе нажимать на сисы, для перемещения экрана на объект - работает почему то с одним слоем, причем не активным. В данном случае, если из примера, то [zdaniya_soorujeniya_trial_1]. Если на сисы этого слоя нажимать - экран перемещает, если из других слоев то не перемещает.
WayTree. Дерево путей. Связанные по направлению
 
Большое спасибо!
WayTree. Дерево путей. Связанные по направлению
 
Заполнение группы работает долго. Можно как то иначе сделать? В смысле без цикла с добавлением в группу объектов по одному.
[IMG WIDTH=438 HEIGHT=222][/IMG]
Изменено: Алексей Демин - 03.02.2025 17:22:48
WayTree. Дерево путей. Связанные по направлению
 
Добрый день. Есть необходимость нажатием макроса выводить в окно сообщений нагрузки связанных по направлению после узла. Написал вот такой макрос. Он хоть и работает, но на большом числе объектов - не достаточно быстро. Возможно существует способ более быстро решить данную задачу?
[CODE]Sub WayTree

Set Out = Zulu.OpenOutputChannel("Сообщения")


Out.Clear


Set L = Zulu.ActiveMapDoc.Layers.Active


L.Selection.Clear

CurrentSYS = L.CurrentID

Out.Put Cstr(CurrentSYS) + Chr(10)

set MWayTree = L.GetShortWayTreeEx(CInt(CurrentSYS),2)

Out.Put Cstr(MWayTree.Count) + Chr(10)

For i=0 to MWayTree.Count-1
   
   L.Selection.AddElem(MWayTree.Item(i))
   
   
   Next
   
Lname = L.UserName
Set Rslt = L.ExecSQL("CONST @Layer = '"+Lname+"'; "& vbLf & _
"SEL ECT Round(SUM([Расчетная нагрузка на отопление, Гкал/ч]),2) as Qот,"& vbLf & _
"Round(SUM([Расчетная нагрузка на ГВС, Гкал/ч]),2) as Qгвс,"& vbLf & _
"Round(SUM([Расчетная нагрузка на вентиляцию, Гкал/ч]),2) as Qвент"& vbLf & _
"fr om @Layer as L "& vbLf & _
"where geometry.selected()=1 and L.typeid=3")

Set r = Rslt.DataSet
Out.PrintDataSet r, 8 + &H100

L.Selection.Clear

End Sub
[/CODE]
Вычисление площади поверхности земли. TIN
 
Отлично. Большое спасибо!
Вычисление площади поверхности земли. TIN
 
Добрый день. Просто хочу уточнить. Вопрос остался тот же. Не появилось ли какого-то способа автоматизации функции "задать регион"? Или может быть появился другой способ расчета площади поверхности земли с учетом геодезических отметок слоя рельефа?
Создать объект на конечной/начальной точке участка по условию пересечения с другим слоем, VBS, координаты
 
IntersectByRadius действительно оказался очень полезным. Часто бывает, что в площадном объекте лежит много маленьких участков, но этот метод как раз помогает, если добавить условие "если число объектов полностью попавших в радиус 2х метров <1 = истина". 2 метра радиус хорошо подходит. Ну это конечно, если в исходном слое есть узлы. В слое, где 8600 домов без метода IntersectByRadius, получалось 1800 домов, где были созданы лишние потребители, с этим методом их было меньше 20. Оставлю макрос на всякий случай.


[CODE]Sub create_obj_in_line

Set Out = Zulu.OpenOutputChannel("Сообщения")

Set L = CreateObject("ZuluLib.Layer")

Set Line_ob = CreateObject("ZuluLib.PolyLine")
Set objz = CreateObject("ZuluLib.ZPoint")
Out.Clear


L.Open "..."

Set Keys_uch = L.ElementKeys.SelectByType(7,0)

'L.StartSequentialWriteMode

For i = 1 To Keys_uch.Count
   
set Line_ob = L.Elements.getElement(Keys_uch.Item(i)).PolyLine    
Point_X = Line_ob.GetX(Line_ob.NumTops)
Point_y = Line_ob.GetY(Line_ob.NumTops)
sys_polygon = L.GetClosestElementByXY(Point_X+0.000002, Point_y, 0, False,objz)
If sys_polygon > 0 and L.Elements.GetElement(sys_polygon).TypeID=5 and L.IntersectByRadius(Point_X+0.000002,Point_y,0.00002,1,0).Count<1 Then
       L.AddSimpleSymbol Point_X+0.000002, Point_y, 0, 1, 300, 0
       'Out.Put Cstr(sys_polygon) + CHR(10)
       Out.Put Cstr(sys_polygon) + CHR(10)
end if


Next
   'L.FinishSequentialWriteMode

Out.Put "Готово"
End Sub
[/CODE]
Создать объект на конечной/начальной точке участка по условию пересечения с другим слоем, VBS, координаты
 
Понял, спасибо!
Создать объект на конечной/начальной точке участка по условию пересечения с другим слоем, VBS, координаты
 
Изначально пробовал в разных слоях - результат был тот же. Сейчас попробовал прибавлять к координатам небольшие значения, чтобы сместить точки - не помогло, результат не изменился. Посмотрел какие сисы он пишет в sys_polygon - действительно, пишет все подряд, не только полигоны, а что попало под 5 пикселей вокруг точки с учетом масштаба. Что делать с этим масштабом, где его указывать я не разобрался. За то нашел метод GetClosestElementByXY. С ним все работает как надо.
Изменено: Алексей Демин - 25.10.2024 19:26:01
Создать объект на конечной/начальной точке участка по условию пересечения с другим слоем, VBS, координаты
 
Увы, работало только на тестовом слое ~500 объектов нормально. На "боевом" почему-то из ~7600 объектов проставляет то 1059, то 1060, то 1063 символа. По разному пытался сделать, но никак. Вот стоят рядом 2 одинаковых дома, в один ставит в другой не ставит.

Вот сам макрос
Sub create_obj_in_line

Set Out = Zulu.OpenOutputChannel("Сообщения")

Set L = CreateObject("ZuluLib.Layer")

Set Line_ob = CreateObject("ZuluLib.PolyLine")    
   
Out.Clear


L.Open "..."

Set Keys_uch = L.ElementKeys.SelectByType(7,0)



For i = 1 To Keys_uch.Count
   
   set Line_ob = L.Elements.getElement(Keys_uch.Item(i)).PolyLine        
   Point_X = Line_ob.GetX(Line_ob.NumTops)
   Point_y = Line_ob.GetY(Line_ob.NumTops)                    
   sys_polygon = L.ElemIDByXY(Point_X, Point_y)
   If sys_polygon <> -1 and L.Elements.GetElement(sys_polygon).TypeID=5 Then
       L.AddSimpleSymbol Point_X, Point_y, 0, 1, 200, 0
       Out.Put Cstr(sys_polygon) + CHR(10)
       end if


   Next
Out.Put "Готово"
End Sub

Вот как это выглядит
[IMG WIDTH=569 HEIGHT=367][/IMG]
Создать объект на конечной/начальной точке участка по условию пересечения с другим слоем, VBS, координаты
 
Да, это серьезно упростило дело. Спасибо. Все получилось.
Создать объект на конечной/начальной точке участка по условию пересечения с другим слоем, VBS, координаты
 
А можете подсказать? Вот есть метод IsPointInContour method (ZGeometry), который проверяет попадание точки в полигон. А как его применить, чтобы не перебирать каждый полигон в цикле по сисам в отдельности. А то получается, что идет прохождение в цикле по всем участкам, берется 1 точка, а потом еще и проверяет в цикле по всем полигонам, боюсь такое будет очень долго работать. Может быть можно как-то получить 1 единый полигон, со все площадных объектов? Или еще как то?
Создать объект на конечной/начальной точке участка по условию пересечения с другим слоем, VBS, координаты
 
[QUOTE] написал:
[QUOTE] написал:
Добрый день. Столкнулся со следующей ситуацией. Есть слой с площадными объектами (домами), а так же есть слой с участками. Требуется на конце участка, который попал в площадной объект создать потребителя. Как создавать символьные объекты по координатам в VBS мне понятно, но не понятно как взять координаты начала или конца участка и можно ли вообще их как то получить?[/QUOTE]
Добрый день. Element.Polyline   [URL=https://politerm.com/zuludoc/zuluax/index.html#Element_PolyLine.html]https://politerm.com/zuludoc/zuluax/index.html#Element_PolyLine.html[/URL]

А у Polyline GetX, GetY, первой и послдней точки[/QUOTE]
Спасибо. Если я все верно понял

Function [B]GetX[/B](TopNum As Long) As Double

TopNum - номер вершины ломаной (нумерация с             единицы).

Для получения первой точки TopNum указываем 1. Для последней используем свойство NumTops.

Создать объект на конечной/начальной точке участка по условию пересечения с другим слоем, VBS, координаты
 
Добрый день. Столкнулся со следующей ситуацией. Есть слой с площадными объектами (домами), а так же есть слой с участками. Требуется на конце участка, который попал в площадной объект создать потребителя. Как создавать символьные объекты по координатам в VBS мне понятно, но не понятно как взять координаты начала или конца участка и можно ли вообще их как то получить?
Большой вес слоя
 
Вопрос снят. Нашел в БД поле BLOB, где были картинки.
Большой вес слоя
 
Добрый день. Попался в руки слой БД (sqlite файл) которого весит 1 гб. Привязанных фотографий нет, фрагментация 0%. Подскажите пожалуйста, как можно выяснить причину большого веса слоя?
sql запрос select в плагине или VBScript
 
А можете сказать, что значит 8 и &H100?
Изменено: Алексей Демин - 10.10.2024 16:32:19
sql запрос select в плагине или VBScript
 
Вот это уже очень даже хорошо, спасибо!
sql запрос select в плагине или VBScript
 
Большое спасибо! Полезная информация
sql запрос select в плагине или VBScript
 
Да, похоже сейчас это единственный вариант, но он имеет существенный минус - красивую таблицу там не собрать. Если бы там можно было сделать выравнивание столбцов то это бы еще куда не шло, но увы
sql запрос select в плагине или VBScript
 
А этот DataSet можно внутри внутри зулы показать? Или только сохранять его?
sql запрос select в плагине или VBScript
 
Добрый день. Возможно ли хоть каким-нибудь образом сделать SQL запрос с командой select в скрипте или плагине? Понимаю, что L.ExecSQL тут не подойдет. Но может быть существует команда, которая просто открывает окно sql запроса и команда, которая вставляет туда текст? В документации я не нашел.
Наименование слоя в переменную в SQL запросе
 
Спасибо большое! Теперь все понятно
Наименование слоя в переменную в SQL запросе
 
Я пробовал много разных вариантов, в том числе и так. Вот что получается в этом случае

Если писать без typeid, то работает. Но скорее всего потому, что from игнорируется. Ведь можно просто написать запрос из двух слов "select sys" и он так же выдаст все сисы.
Изменено: Алексей Демин - 02.10.2024 13:34:29
Наименование слоя в переменную в SQL запросе
 
Вроде бы все по инструкции делаю
Изменено: Алексей Демин - 02.10.2024 14:12:05
Страницы: 1 2 След.