<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Python If Statement with multiple &amp;quot;and&amp;quot; conditions, if not default column value in Data Engineering</title>
    <link>https://community.databricks.com/t5/data-engineering/python-if-statement-with-multiple-quot-and-quot-conditions-if/m-p/127418#M47958</link>
    <description>&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://community.databricks.com/t5/user/viewprofilepage/user-id/114593"&gt;@abueno&lt;/a&gt;&amp;nbsp;.&lt;/P&gt;&lt;P&gt;I'm assuming you're asking how to do this in pyspark. You can use when and otherwise conditional functions to achieve your expected result:&lt;/P&gt;&lt;LI-CODE lang="python"&gt;from pyspark.sql import SparkSession
from pyspark.sql.types import StructType, StructField, StringType

# Schema
schema = StructType([
    StructField("column1", StringType(), True),
    StructField("column2", StringType(), True),
    StructField("column3", StringType(), True),
])

# Sample data
data = [
    ("2024", "DE", "original1"),   
    ("2024", "SC", "original2"),   
    ("2024", "FR", "original3"),   
    ("2023", "DE", "original4"),   
    ("2023", "SC", "original5"),   
    ("2023", "IT", "original6"),   
    ("2022", "DE", "original7"),   
    ("2025", "NL", "original8"),   
]

# Create DataFrame
df = spark.createDataFrame(data, schema)

# Show initial DataFrame
df.show(truncate=False)



from pyspark.sql.functions import when, col

df = df.withColumn(
    "result_column",
    when((col("column1") == "2024") &amp;amp; (col("column2").isin("DE", "SC")), "value1")
    .when((col("column1") == "2024"), "value2")
    .when((col("column1") == "2023") &amp;amp; (col("column2").isin("DE", "SC")), "value3")
    .when((col("column1") == "2023"), "value4")
    .otherwise(col("column3"))
)&lt;/LI-CODE&gt;</description>
    <pubDate>Tue, 05 Aug 2025 07:23:23 GMT</pubDate>
    <dc:creator>szymon_dybczak</dc:creator>
    <dc:date>2025-08-05T07:23:23Z</dc:date>
    <item>
      <title>Python If Statement with multiple "and" conditions, if not default column value</title>
      <link>https://community.databricks.com/t5/data-engineering/python-if-statement-with-multiple-quot-and-quot-conditions-if/m-p/127399#M47950</link>
      <description>&lt;P&gt;Python 3.10.12 I am trying to get these filter results: example:&lt;/P&gt;&lt;P&gt;If "column1" = '2024' and column2 in ('DE','SC') then 'value1" else 'value2'&lt;/P&gt;&lt;P&gt;If "column1" = "2023" and column2 in ('DE,'SC')&lt;/P&gt;&lt;P&gt;then "value3 else "value4"&lt;/P&gt;&lt;P&gt;if the row/record does not fit the criteria above, then return the value in column3.&amp;nbsp; Any ideas?&lt;/P&gt;</description>
      <pubDate>Tue, 05 Aug 2025 01:48:23 GMT</pubDate>
      <guid>https://community.databricks.com/t5/data-engineering/python-if-statement-with-multiple-quot-and-quot-conditions-if/m-p/127399#M47950</guid>
      <dc:creator>abueno</dc:creator>
      <dc:date>2025-08-05T01:48:23Z</dc:date>
    </item>
    <item>
      <title>Re: Python If Statement with multiple "and" conditions, if not default column value</title>
      <link>https://community.databricks.com/t5/data-engineering/python-if-statement-with-multiple-quot-and-quot-conditions-if/m-p/127418#M47958</link>
      <description>&lt;P&gt;Hi&amp;nbsp;&lt;a href="https://community.databricks.com/t5/user/viewprofilepage/user-id/114593"&gt;@abueno&lt;/a&gt;&amp;nbsp;.&lt;/P&gt;&lt;P&gt;I'm assuming you're asking how to do this in pyspark. You can use when and otherwise conditional functions to achieve your expected result:&lt;/P&gt;&lt;LI-CODE lang="python"&gt;from pyspark.sql import SparkSession
from pyspark.sql.types import StructType, StructField, StringType

# Schema
schema = StructType([
    StructField("column1", StringType(), True),
    StructField("column2", StringType(), True),
    StructField("column3", StringType(), True),
])

# Sample data
data = [
    ("2024", "DE", "original1"),   
    ("2024", "SC", "original2"),   
    ("2024", "FR", "original3"),   
    ("2023", "DE", "original4"),   
    ("2023", "SC", "original5"),   
    ("2023", "IT", "original6"),   
    ("2022", "DE", "original7"),   
    ("2025", "NL", "original8"),   
]

# Create DataFrame
df = spark.createDataFrame(data, schema)

# Show initial DataFrame
df.show(truncate=False)



from pyspark.sql.functions import when, col

df = df.withColumn(
    "result_column",
    when((col("column1") == "2024") &amp;amp; (col("column2").isin("DE", "SC")), "value1")
    .when((col("column1") == "2024"), "value2")
    .when((col("column1") == "2023") &amp;amp; (col("column2").isin("DE", "SC")), "value3")
    .when((col("column1") == "2023"), "value4")
    .otherwise(col("column3"))
)&lt;/LI-CODE&gt;</description>
      <pubDate>Tue, 05 Aug 2025 07:23:23 GMT</pubDate>
      <guid>https://community.databricks.com/t5/data-engineering/python-if-statement-with-multiple-quot-and-quot-conditions-if/m-p/127418#M47958</guid>
      <dc:creator>szymon_dybczak</dc:creator>
      <dc:date>2025-08-05T07:23:23Z</dc:date>
    </item>
  </channel>
</rss>

