如果单元格值以特定字符串开头,如何从范围中复制行?
How to copy rows from a range if the cell value starts with particular string?
我有一个列表,其中包含 1000 个地理参数——这些参数会根据文件类型而有所不同——在一个列中。我想复制以字符串开头的行“File, Geometry, Feature Count, Layer SRS, GEOGCS, PROJGCS, etc... ”(图像)到下一栏。参数很少,例如 - PROJGCS 可能存在于一个文件中,但不存在于另一个文件中。
您可以使用高级过滤器,如下所示:
Sub FilterThings()
'Add header row and call it something
Rows("1:1").Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
Range("A1").FormulaR1C1 = "Bananas"
'Create named range to use in filter
ActiveWorkbook.Names.Add Name:="Source", RefersToR1C1:=Replace(Range("A1").CurrentRegion.Address(True, True, xlR1C1, True), "[" & ActiveWorkbook.Name & "]", "=")
'Add in criteria
Range("P1").FormulaR1C1 = "Bananas"
Range("P2").FormulaR1C1 = "=""File*"""
Range("P3").FormulaR1C1 = "=""Geometry*"""
Range("P4").FormulaR1C1 = "=""Feature Count*"""
Range("P5").FormulaR1C1 = "=""Layer SRS*"""
Range("P6").FormulaR1C1 = "=""GEOGCS*"""
Range("P7").FormulaR1C1 = "=""PROJGCS*"""
'Create named range to use in filter
ActiveWorkbook.Names.Add Name:="Criteria", RefersToR1C1:=Replace(Range("P1").CurrentRegion.Address(True, True, xlR1C1, True), "[" & ActiveWorkbook.Name & "]", "=")
'Filter to Location
Range("Source").AdvancedFilter Action:=xlFilterCopy, CriteriaRange:=Range("Criteria"), CopyToRange:=Range("G1")
'Delete Criteria column
Columns("P:P").Delete Shift:=xlToLeft
'Delete Header Bananas row
Rows("1:1").Delete Shift:=xlUp
'Delete named ranges
ActiveWorkbook.Names("Criteria").Delete
ActiveWorkbook.Names("Extract").Delete
ActiveWorkbook.Names("Source").Delete
End Sub
如果您已经有了 header,您可以用香蕉代替其他东西,或者将那部分省略。在这里,我假设您的数据只是在从第 1 行开始的 A 列中,并且任意将其放在 G 列中,这和您放置标准的位置可以更改而不会产生不利影响。
我有一个列表,其中包含 1000 个地理参数——这些参数会根据文件类型而有所不同——在一个列中。我想复制以字符串开头的行“File, Geometry, Feature Count, Layer SRS, GEOGCS, PROJGCS, etc... ”(图像)到下一栏。参数很少,例如 - PROJGCS 可能存在于一个文件中,但不存在于另一个文件中。
您可以使用高级过滤器,如下所示:
Sub FilterThings()
'Add header row and call it something
Rows("1:1").Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
Range("A1").FormulaR1C1 = "Bananas"
'Create named range to use in filter
ActiveWorkbook.Names.Add Name:="Source", RefersToR1C1:=Replace(Range("A1").CurrentRegion.Address(True, True, xlR1C1, True), "[" & ActiveWorkbook.Name & "]", "=")
'Add in criteria
Range("P1").FormulaR1C1 = "Bananas"
Range("P2").FormulaR1C1 = "=""File*"""
Range("P3").FormulaR1C1 = "=""Geometry*"""
Range("P4").FormulaR1C1 = "=""Feature Count*"""
Range("P5").FormulaR1C1 = "=""Layer SRS*"""
Range("P6").FormulaR1C1 = "=""GEOGCS*"""
Range("P7").FormulaR1C1 = "=""PROJGCS*"""
'Create named range to use in filter
ActiveWorkbook.Names.Add Name:="Criteria", RefersToR1C1:=Replace(Range("P1").CurrentRegion.Address(True, True, xlR1C1, True), "[" & ActiveWorkbook.Name & "]", "=")
'Filter to Location
Range("Source").AdvancedFilter Action:=xlFilterCopy, CriteriaRange:=Range("Criteria"), CopyToRange:=Range("G1")
'Delete Criteria column
Columns("P:P").Delete Shift:=xlToLeft
'Delete Header Bananas row
Rows("1:1").Delete Shift:=xlUp
'Delete named ranges
ActiveWorkbook.Names("Criteria").Delete
ActiveWorkbook.Names("Extract").Delete
ActiveWorkbook.Names("Source").Delete
End Sub
如果您已经有了 header,您可以用香蕉代替其他东西,或者将那部分省略。在这里,我假设您的数据只是在从第 1 行开始的 A 列中,并且任意将其放在 G 列中,这和您放置标准的位置可以更改而不会产生不利影响。