Невозможно просмотреть несколько миниатюр подряд

Чтобы выбрать строки, значение столбца которых равно скаляру, some_value, используйте ==:

df.loc[df['column_name'] == some_value]

Чтобы выбрать строки, значение столбца которых в итерабельном, some_values, используйте isin:

df.loc[df['column_name'].isin(some_values)]

Объединить несколько условий с &:

df.loc[(df['column_name'] == some_value) & df['other_column'].isin(some_values)]

Выбрать строки, значение столбца не равно some_value, используйте !=:

df.loc[df['column_name'] != some_value]

isin возвращает булевскую серию, поэтому для выбора строк, значение которых не в some_values, отмените булевскую серию используя ~:

df.loc[~df['column_name'].isin(some_values)]

Например,

import pandas as pd
import numpy as np
df = pd.DataFrame({'A': 'foo bar foo bar foo bar foo foo'.split(),
                   'B': 'one one two three two two one three'.split(),
                   'C': np.arange(8), 'D': np.arange(8) * 2})
print(df)
#      A      B  C   D
# 0  foo    one  0   0
# 1  bar    one  1   2
# 2  foo    two  2   4
# 3  bar  three  3   6
# 4  foo    two  4   8
# 5  bar    two  5  10
# 6  foo    one  6  12
# 7  foo  three  7  14

print(df.loc[df['A'] == 'foo'])

дает

     A      B  C   D
0  foo    one  0   0
2  foo    two  2   4
4  foo    two  4   8
6  foo    one  6  12
7  foo  three  7  14

Если у вас несколько значений вы хотите включить, поместить их в список (или, в более общем плане, любой итерабельный) и использовать isin:

print(df.loc[df['B'].isin(['one','three'])])

дает

     A      B  C   D
0  foo    one  0   0
1  bar    one  1   2
3  bar  three  3   6
6  foo    one  6  12
7  foo  three  7  14

Примечание, однако, если вы хотите сделать это много раз, более эффективно сначала сделать индекс, а затем использовать df.loc:

df = df.set_index(['B'])
print(df.loc['one'])

дает

       A  C   D
B              
one  foo  0   0
one  bar  1   2
one  foo  6  12

или, чтобы включить несколько значений из использования индекса df.index.isin:

df.loc[df.index.isin(['one','two'])]

дает

       A  C   D
B              
one  foo  0   0
one  bar  1   2
two  foo  2   4
two  foo  4   8
two  bar  5  10
one  foo  6  12
0
задан Zartch 18 January 2019 в 17:45
поделиться

1 ответ

Вы генерируете row для каждого списка. В идеале вы хотели бы только списки. Таким образом, вы можете сделать:

      {% if listings %}
      {% for listing in listings %}

      {% if forloop.counter0|divisibleby:3 %}<div class="row">{% endif %}

      <!-- Single Featured Property -->

        <div class="col-x-6 col-md-4">
          <div class="single-featured-property mb-50">
          <!-- Property Thumbnail -->
          <div class="property-thumb">
              <img src="{{listing.photo_main.url}}" alt="">
              <div class="tag">
                <span>For Sale</span>
              </div>
              <div class="list-price">
                  <p>₹{{listing.price}}</p>
              </div>
          </div>
          <!-- Property Content -->
          <div class="property-content">
              <h5>{{listing.title}}</h5>
              <p class="location"><img src="{% static 'img/icons/location.png'%}" alt="">{{listing.adderss}}</p>
              <p>{{listing.description}}</p>
              <div class="property-meta-data d-flex align-items-end justify-content-between">
                  <div class="new-tag">
                      <img src="{% static 'img/icons/new.png'%}" alt="">
                  </div>
                  <div class="bathroom">
                      <img src="{% static 'img/icons/bathtub.png'%}" alt="">
                      <span>{{listing.bathrooms}}</span>
                  </div>
                  <div class="garage">
                      <img src="{% static 'img/icons/garage.png'%}" alt="">
                      <span>{{listing.garage}}</span>
                  </div>
                  <div class="space">
                      <img src="{% static 'img/icons/space.png'%}" alt="">
                      <span>{{listing.sqft}} sq ft</span>
                  </div>
              </div>
          </div>
      </div>
      </div>
      {% endfor %}
      </div>

      {% endif %}

Или, если вы хотите сгенерировать строку для каждых трех списков, которые вы делаете:

      {% if listings %}
      <div class="row">
      {% for listing in listings %}

      <!-- Single Featured Property -->

        <div class="col-x-6 col-md-4">
          <div class="single-featured-property mb-50">
          <!-- Property Thumbnail -->
          <div class="property-thumb">
              <img src="{{listing.photo_main.url}}" alt="">
              <div class="tag">
                <span>For Sale</span>
              </div>
              <div class="list-price">
                  <p>₹{{listing.price}}</p>
              </div>
          </div>
          <!-- Property Content -->
          <div class="property-content">
              <h5>{{listing.title}}</h5>
              <p class="location"><img src="{% static 'img/icons/location.png'%}" alt="">{{listing.adderss}}</p>
              <p>{{listing.description}}</p>
              <div class="property-meta-data d-flex align-items-end justify-content-between">
                  <div class="new-tag">
                      <img src="{% static 'img/icons/new.png'%}" alt="">
                  </div>
                  <div class="bathroom">
                      <img src="{% static 'img/icons/bathtub.png'%}" alt="">
                      <span>{{listing.bathrooms}}</span>
                  </div>
                  <div class="garage">
                      <img src="{% static 'img/icons/garage.png'%}" alt="">
                      <span>{{listing.garage}}</span>
                  </div>
                  <div class="space">
                      <img src="{% static 'img/icons/space.png'%}" alt="">
                      <span>{{listing.sqft}} sq ft</span>
                  </div>
              </div>
          </div>
      </div>
      </div>
      {% if forloop.counter0|divisibleby:3 %}</div>{% endif %}
      {% endfor %}

      {% endif %}
0
ответ дан schillingt 18 January 2019 в 17:45
поделиться
Другие вопросы по тегам:

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