Предоставить __repr__ для объекта функции [duplicate]

Вот еще одна версия, которую я написал для сохранения картографической недвижимости, которая помещает указатель infowindow на фактический лат и длинный маркер, а также временно скрывает маркер, пока отображается информационное окно.

It также устраняет стандартное назначение маркера и ускоряет обработку, напрямую назначая новый маркер массиву маркеров при создании маркеров. Обратите внимание, однако, что дополнительные свойства были добавлены как к маркеру, так и к infowindow, поэтому этот подход является немного нетрадиционным ... но это я!

Это никогда не упоминается в этих заданных вопросах, что стандартное infowindow НЕ помещается в lat и lng точки маркера, а скорее в верхнюю часть изображения маркера. Видимость маркера должна быть скрыта, чтобы это работало, иначе API Карт снова запустит привязку infowindow обратно в верхнюю часть изображения маркера.

Ссылка на маркеры в массиве «маркеры» создается немедленно при объявлении маркера для любых дополнительных задач обработки, которые могут потребоваться позже (скрытие / показ, захват коордов и т. д.). Это сохраняет дополнительный шаг назначения объекта маркера «маркеру», а затем нажимает «маркер» на массив маркеров ... много ненужной обработки в моей книге.

Во всяком случае, другой подход на infowindows и надеемся, что это поможет вам информировать и вдохновить вас.

    var locations = [
      ['Bondi Beach', -33.890542, 151.274856, 4],
      ['Coogee Beach', -33.923036, 151.259052, 5],
      ['Cronulla Beach', -34.028249, 151.157507, 3],
      ['Manly Beach', -33.80010128657071, 151.28747820854187, 2],
      ['Maroubra Beach', -33.950198, 151.259302, 1]
    ];
    var map;
    var markers = [];

    function init(){
      map = new google.maps.Map(document.getElementById('map_canvas'), {
        zoom: 10,
        center: new google.maps.LatLng(-33.92, 151.25),
        mapTypeId: google.maps.MapTypeId.ROADMAP
      });

      var num_markers = locations.length;
      for (var i = 0; i < num_markers; i++) {  
        markers[i] = new google.maps.Marker({
          position: {lat:locations[i][1], lng:locations[i][2]},
          map: map,
          html: locations[i][0],
          id: i,
        });

        google.maps.event.addListener(markers[i], 'click', function(){
          var infowindow = new google.maps.InfoWindow({
            id: this.id,
            content:this.html,
            position:this.getPosition()
          });
          google.maps.event.addListenerOnce(infowindow, 'closeclick', function(){
            markers[this.id].setVisible(true);
          });
          this.setVisible(false);
          infowindow.open(map);
        });
      }
    }

google.maps.event.addDomListener(window, 'load', init);

Здесь работает JSFiddle

Дополнительная заметка Вы заметите в этом Данные примера Google - четвертое место в массиве «местоположения» с номером. Учитывая это в этом примере, вы также можете использовать это значение для идентификатора маркера вместо текущего значения цикла, так что ...

var num_markers = locations.length;
for (var i = 0; i < num_markers; i++) {  
  markers[i] = new google.maps.Marker({
    position: {lat:locations[i][1], lng:locations[i][2]},
    map: map,
    html: locations[i][0],
    id: locations[i][3],
  });
};

14
задан beardc 4 June 2012 в 02:36
поделиться

3 ответа

Да, если вы хотите отказаться от функции, фактически являющейся функцией.

Сначала определите класс для нашего нового типа:

import functools
class reprwrapper(object):
    def __init__(self, repr, func):
        self._repr = repr
        self._func = func
        functools.update_wrapper(self, func)
    def __call__(self, *args, **kw):
        return self._func(*args, **kw)
    def __repr__(self):
        return self._repr(self._func)

Добавьте в декоратор function:

def withrepr(reprfun):
    def _wrap(func):
        return reprwrapper(reprfun, func)
    return _wrap

И теперь мы можем определить репер вместе с функцией:

@withrepr(lambda x: "<Func: %s>" % x.__name__)
def mul42(y):
    return y*42

Теперь repr(mul42) создает '<Func: mul42>'

16
ответ дан kwatford 1 September 2018 в 03:55
поделиться

Нет, потому что repr(f) выполняется как type(f).__repr__(f).

6
ответ дан JBernardo 1 September 2018 в 03:55
поделиться

Для этого вам нужно будет изменить функцию __repr__ для данного класса, которая в этом случае является встроенным классом функций (types.FunctionType). Поскольку в Python вы не можете редактировать встроенные классы, только подклассировать их, вы не можете.

Однако есть два подхода, которым вы могли бы следовать:

  1. Обернуть некоторые функции в виде kwatford Предлагаемый
  2. Создайте свой собственный протокол представления с помощью собственной функции воспроизведения. Например, вы можете определить функцию myrepr, которая сначала ищет методы __myrepr__, которую вы не можете добавить в класс функций, но вы можете добавить ее к отдельным объектам функции, как вы предлагаете (а также к вашим пользовательским классам и объектам) , затем по умолчанию будет указано, если __myrepr__ не найден. Возможная реализация для этого будет:
    def myrepr(x):
      try:
        x.__myrepr__
      except AttributeError:
        return repr(x)
      else:
        return x.__myrepr__()
    
    Затем вы можете определить методы __myrepr__ и использовать функцию myrepr. Кроме того, вы также можете __builtins__.repr = myrepr сделать свою функцию по умолчанию repr и продолжать использовать repr. Этот подход в конечном итоге сделает именно то, что вы хотите, хотя редактирование __builtins__ может не всегда быть желательным.
3
ответ дан Sean Allred 1 September 2018 в 03:55
поделиться
Другие вопросы по тегам:

Похожие вопросы: